Template talk:doi
Problem DOI
[edit]This DOI doesn't work in the template. I tried several character encodings. It's in Sea_level_rise#References. (SEWilco 03:01, 22 May 2005 (UTC))
- 10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2
This solution seems to work:
{{doi|<nowiki>10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2}}</nowiki>
The above is generated by:
{{doi|<nowiki>10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2</nowiki>}}
It may be a problem if the doi contains the string </nowiki>... Paolo Liberatore (Talk) 20:45, 29 November 2005 (UTC)
- A DOI that is made specifically so that it doesn't work on wikipedia. That would be a sight! Ansell 03:32, 8 April 2006 (UTC)
- Numerous DOIs using the <,>,[ and ] characters will notwork on these templates.I am not sure how to force them to display properly. Numericla entities do not appear to work. See also User:Circeus/Maple for two other examples. Circeus 14:48, 25 July 2006 (UTC)
- My problematic DOIs are 10.2179/0008-7475(2004)069<0230:SN>2.0.CO;2 and 10.1656/1092-6194(2005)012[0023:SASEOA]2.0.CO;2 Circeus 14:55, 25 July 2006 (UTC)
It appears to be a MediaWiki bug, in that the character entity (which would be the correct way to do it) is terminating the link:
doi:10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2
Using a URL escape works; however, since the same template parameter is also used for the display text, it does not display correctly:
doi:10.1175/1520-0442(2002)015%3C0487:SOCASI%3E2.0.CO;2
--cesarb 15:35, 25 July 2006 (UTC)
- Guess that's going to be our solution for now. I'll list the escapes when I have some time. Circeus 17:26, 25 July 2006 (UTC)
- See also [1], [2]. --Ligulem 23:17, 25 July 2006 (UTC)
- Has this Mediawiki bug been reported?
- For problem URLs, you could add another variable and have one variable for the displayed value and one for the percent-encoded value. — Omegatron 17:30, 11 August 2006 (UTC)
Add to template
[edit]Hi, this template is locked, so I thought I'd let someone know who has the permissions to add a bit of a "See also" section at the end:
==See also== *[[Template:Doi-inline]]
Thanks.+mwtoews 22:40, 22 December 2006 (UTC)
- The documentation page is not locked. It's at Template:Doi/doc. Feel free to edit that. It's transcluded into what you see on the template:Doi page (add "?action=purge" to the end of the address line in your browser if it's not updated after your edit). --Ligulem 23:47, 22 December 2006 (UTC)
- Aha, that's cleaver. Thanks, that was new to me! Done.+mwtoews 07:10, 24 December 2006 (UTC)
URL encoding
[edit]Is there a good reason why you have two separate parameters instead of just using http://dx.doi.org/{{urlencode:{{{1}}}}}
? — Omegatron 02:19, 18 February 2007 (UTC)
- I think I tried and failed to get anything out of Whatever you did went wrong: you transcluded Template:Urlencode instead of the magic word {{URLENCODE}}.. Besides, by now, we risk breaking too many uses of the template without real benefits.Circeus 22:48, 19 February 2007 (UTC)
- The problem is bug 9031: urlencode does not treat < and > properly. -- Jitse Niesen (talk) 10:36, 18 August 2007 (UTC)
- This bug is fixed in newer MediaWiki versions (tried it today). In principle we could change the template. The documentation of urlencode templte states this, too: Help:Parser_function#URLENCODE. -- Thetaphi (talk) 19:30, 24 March 2008 (UTC)
- haven't looked at this in a while. Can we fix it while remaining backwards-compatible? — Omegatron 23:29, 24 March 2008 (UTC)
- Original
- Original with label
- {{doi | id = 10.1175/1520-0442(2002)015%3C0487:SOCASI%3E2.0.CO;2 | label = 10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2 }}
- Proposed
- Proposed with label
- Original
- doi:10.1234/something[bracketother]
- Original with label
- {{doi|id = 10.1234/something%5Bbracket%5Dother |label = 10.1234/something[bracket]other}}
- Proposed
- DOI:10.1234/something[bracketother]
- Proposed with label
- DOI:10.1234/something[bracketother]
delete this template
[edit]Doi have add interwiki map, plese use [[DOI:XXXX]]: DOI:10.1000/182.--Shizhao 13:00, 23 July 2007 (UTC)
- Shouldn't that be http://dx.doi.org/10.1000/182 instead of http://www.doi.org/10.1000/182? Tizio 13:47, 23 July 2007 (UTC)
- Never mind, I asked the folks on meta myself. Tizio 13:51, 23 July 2007 (UTC)
- Have fix--Shizhao (talk) 08:45, 30 January 2008 (UTC)
So
- DOI:10.1175/1520 instead of doi:10.1175/1520?
Doesn't handle special cases:
- [[DOI:10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2]]
- doi:10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2
- DOI:10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2
Caps
[edit]Can we have the output of the template be "DOI:" instead of "doi:" ? This is to bring this template in line with the {{cite journal}} output. --Rifleman 82 04:26, 22 October 2007 (UTC)
- This is not good. DOIs should generally be treated as URIs and URIs should spell the "protocol"-part in lowercase (e.g. http: ftp: hdl: doi: urn:). This was discussed on German wikipedia, too and the spelling was changed to lowercase. I am member of one of the non-crossref DOI-supplying organizations (http://www.std-doi.de) and we try to propse the URI notation of DOIs. Almost all publishers use doi:, examples from our field are: doi:10.1594/PANGAEA.55366, doi:10.1016/S0037-0738(99)00071-8. One example how to cite a DOI: How to cite with DOI @ Elsevier -- Thetaphi (talk) 13:05, 26 March 2008 (UTC)
- By the way: {{cite journal}} was changed to lowercase long time ago! -- Thetaphi (talk) 13:15, 26 March 2008 (UTC)
- Seems convincing, so I changed it back to use "doi:" . Thanks for your comment. -- Jitse Niesen (talk) 14:22, 26 March 2008 (UTC)
- By the way: {{cite journal}} was changed to lowercase long time ago! -- Thetaphi (talk) 13:15, 26 March 2008 (UTC)
New #urlencode function
[edit]{{editprotected}}
With the new #urlencode parserfunction, there's now no need for the label parameter.
Please replace the contents of this page with those of Template:doi/editprotected.
This will automatically encode the DOI when generating a link address.
Smith609 Talk 12:54, 6 May 2008 (UTC)
- Done -CapitalR (talk) 13:12, 6 May 2008 (UTC)
- Wow, quick work! Thank you. Smith609 Talk 13:33, 6 May 2008 (UTC)
{{editprotected}}
- Hi, another fix to broken links resulting from square brackets in DOI syntax. Again, please copy from Template:doi/editprotected (backlinks edit).
- Before fix: doi:10.1235/example[squarebracket/doi] ... doi:10.1038/nature145653
- After fix: doi:10.1235/example[square]bracket/doi ... doi:10.1038/nature145653
- Done --CapitalR (talk) 10:41, 7 May 2008 (UTC)
Parenthesis?
[edit]The following DOI contains parentheses, and seems to fail to link properly:
doi:10.1016/S0140-6736(98)05145-9
(The link is there, but it the text of the DOI isn't linked.) Where is the problem here? 13:20, 14 May 2008 (UTC)
I have the same problem with doi:10.1016/S0168-0072(99)00032-9, apparently all Elsevier DOIs are affected. I notice that deleting the slash also makes the problem disappear, so it is not necessarily related just to the parentheses. URL encoding does not help, and in fact, breaks the link: doi:10.1016%2FS0168-0072%2899%2900032-9. Character entities do not help either: doi:10.1016/S0168-0072(99)00032-9.
IIRC, the offending doi displayed OK two weaks ago, I thus strongly suspect that the bug is caused by one of the recent changes to the template. Can someone revert it to the working March 26 version, and properly debug it before making further sweeping changes? — EJ (talk) 15:59, 14 May 2008 (UTC)
- I have reverted. The reason id/label was implemented was that, for some reason, the #urlencode simply did not work (I think there's a bug filed for it, actually). Hence the new form made the link practically invisible. Circeus (talk) 21:45, 10 June 2008 (UTC)
- Thanks. — Emil J. (formerly EJ) 09:23, 11 June 2008 (UTC)
Parameter “label”
[edit]I don't understand what the parameter “label” is good for. The version without this parameter produces exactly the same link as the one with the parameter:
{{doi|id = 10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2}}
- {{doi|id = 10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2}}
{{doi | id = 10.1175/1520-0442(2002)015%3C0487:SOCASI%3E2.0.CO;2 | label = 10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2 }}
- {{doi | id = 10.1175/1520-0442(2002)015%3C0487:SOCASI%3E2.0.CO;2 | label = 10.1175/1520-0442(2002)015<0487:SOCASI>2.0.CO;2 }}
Special characters (see old version of doc) have to be replaced in the parameter “id” anyway. --Leyo 22:11, 10 June 2008 (UTC)
- At some points, it appears that the way urls are handled was changed at they now allow unescaped carets (I was not aware of this), which was not possible back in December/January. Any attempt to use the new format with brackets still broke the template, though, hence my revert. I'll just rewrite the current documentation to account for this. Circeus (talk) 23:28, 10 June 2008 (UTC)
- Better now? Only square brackets require the id/label system.Circeus (talk) 23:32, 10 June 2008 (UTC)
- Please have a look at the source code of my examples. Both types of brackets have to be replaced in the parameter “id” as shown here. Like this, the link is working and the link text is correct, even without using the parameter “label”. --Leyo 08:12, 11 June 2008 (UTC)
- I looked at that and spent twenty minutes Monday fiddling and trying to figure out just what the heck was to be replaced by what in which parameters before giving up. Whatever one was supposed to do, the page was not clear enough about what it was. Circeus (talk) 17:25, 11 June 2008 (UTC)
- I don't exactly understand what you mean. However, it seems that this parameter is not in use very often: Template Tiger result. --Leyo 19:05, 14 June 2008 (UTC)
- I looked at that and spent twenty minutes Monday fiddling and trying to figure out just what the heck was to be replaced by what in which parameters before giving up. Whatever one was supposed to do, the page was not clear enough about what it was. Circeus (talk) 17:25, 11 June 2008 (UTC)
- Please have a look at the source code of my examples. Both types of brackets have to be replaced in the parameter “id” as shown here. Like this, the link is working and the link text is correct, even without using the parameter “label”. --Leyo 08:12, 11 June 2008 (UTC)
{{editprotected}}
- Done Cheers, PeterSymonds (talk) 12:03, 24 June 2008 (UTC)
The label parameter is now redundant due to the new {{#tag:}} parser function.
Please copy the new source from Template:Doi/edit.
Example:
{{doi/edit|10.1020/201[213]153<asf>au4hbn(qi4uhukj0)--}}
doi:10.1020/201[213]153<asf>au4hbn(qi4uhukj0)--
Martin (Smith609 – Talk) 11:17, 24 June 2008 (UTC)
Tweak for print
[edit]{{edit protected}}
Replace current code with this one (copy-paste)
<!-- -->{{hide in print<!-- -->|[[Digital object identifier|doi]]:[http://dx.doi.org/{{urlencode:{{{1|{{{id}}}}}}}} {{#tag:nowiki|{{{1|{{{id}}}}}}}}]<!-- -->}}<!-- -->{{only in print<!-- -->|doi:{{{1|{{{id}}}}}}<!-- -->}}<!-- --><noinclude> {{documentation}}</noinclude>
This will help cleanup PDF and Books. Headbomb {ταλκκοντριβς – WP Physics} 21:44, 3 March 2010 (UTC)
Add doi-check
[edit]This edit request has been answered. Set the |answered= or |ans= parameter to no to reactivate your request. |
If an admin could put {{doi/sandbox}} into {{doi}}, that would be peachy. What it does is check if the DOI starts with '10.Foobar'. If not, it throws an error message and populates Category:Pages with DOI errors. It's tested and everything. Headbomb {talk / contribs / physics / books} 19:13, 6 March 2012 (UTC)
- Done --Redrose64 (talk) 19:42, 6 March 2012 (UTC)
Reccomendation to use {{cite doi}} is outdated
[edit]This page says:
- Usually, this template is preferred:
- {{cite doi|10.1016/j.coi.2004.08.001}}
However, if you follow the link below to Template:cite doi you see two big warning signs telling you to use Template:cite journal instead. Can this page be updated to reflect the new consensus? --holizz (talk) 13:39, 26 April 2015 (UTC)
- Exactly. What's the difference? We still do know, two years later... KDS4444 (talk) 01:36, 13 August 2017 (UTC)
Doi and only in print template
[edit]Please check Template talk:Only in print#Template DOI is using this template?. --Obsuser (talk) 22:26, 21 July 2016 (UTC)
RFCs on citations templates and the flagging free-to-read sources
[edit]See
- Wikipedia:Village pump (proposals)#Access locks: Visual Design RFC
- Wikipedia:Village pump (proposals)#Access Locks: Citation Template Behaviour RFC
Headbomb {talk / contribs / physics / books} 17:04, 29 October 2016 (UTC)
Usage
[edit]The template documentation given here explains how to use this template to produce a link to a DOI document without producing an error. Which is great. But it does NOT explain to an editor WHERE to use such a template, which means knowledge of correct application of the template is presumed. I have my own guesses, but it would be great if someone involved with this template provided at least a few sentences in the template documentation explaining where a person might want to use this template on Wikipedia. Thank you. KDS4444 (talk) 01:35, 13 August 2017 (UTC)
Template-protected edit request on 25 August 2017
[edit]This edit request has been answered. Set the |answered= or |ans= parameter to no to reactivate your request. |
Please remove dx.
from the template: "DOIs may be structured to use the default public DOI proxy server https://doi.org (note that https is preferred over http, and that dx.doi.org, an earlier syntax, will remain fully supported but is no longer preferred)."[3] Paradoctor (talk) 21:25, 25 August 2017 (UTC)
Suggested simplification
[edit]OP is a globally-blocked sock.
|
---|
A doi has two functions, right? (1) As an identifier, and (2) as a (more or less) stable link to a web page. I would question the sense of actually displaying the identifier in WP articles, as seeing the identifier has rather few uses that I can see, but it adds considerably to complexity and clutter, thereby distracting from what is really important. It is somewhat like using pi, in the sense that you can use pi in a calculation without needing to see the actual approximation being used. So, why not display doi links just as the term doi, without displaying the identifier bit? If someone really did want to see what the identifier actually is, for some reason, then they still have 3 easy options: (1) Go into edit mode to see the doi link in full; or (2) Use the 'Copy link address' facility on their browser; or (3) Click on the doi link and see the full identifier on the linked web page. Generally speaking, I would suggest that articles with lots of unnecessary identifiers showing is a bad idea. Thoughts? Comments? GruesomeBalls (talk) 08:59, 3 November 2020 (UTC)
|
DOIs with spaces in them
[edit]{{{Doi|10.1126/science. 1140516}}}
encodes as https://doi.org/10.1126/science.+1140516 instead of as https://doi.org/10.1126/science.%201140516 Note that this DOI has a space in it! AManWithNoPlan (talk) 19:09, 27 January 2021 (UTC)
- switched to PATH uri encoding.
- —Trappist the monk (talk) 19:47, 27 January 2021 (UTC)
- I am not sure anything can be done about this but it should probably be noted that this also fails with interwikilinks, e.g.: doi:10.1126/science. 1140516 renders the link with an underscore instead of a space. —Uzume (talk) 01:45, 7 December 2021 (UTC)
- It might be better to give an example that has the possibility of linking to a valid DOI. – Jonesey95 (talk) 03:14, 7 December 2021 (UTC)
- The example doi in this discussion was once a working identifier (with the space); it still works to some extent because you don't get the doi.org error page but rather you get a 404 error at science.org. I expect that that doi has been replaced with something else. Regardless, it is doubtful that the interwikilink form (
[[doi:10.1126/science. 1140516]]
) can ever be made to work because MediaWiki treats interwikilinks like any regular wikilink: urls are created from the wikilink syntax such that spaces (even when percent encoded) are replaced with underscores. And why isdoi:
an interwiki prefix anyway? The template works because it does not replace spaces with underscores. I suppose one might wander over to phabricator and propose that if non-mediawiki sites can be interwikilinked, the 'interwiki' urls created should not use underscores for spaces in the url. - This particular doi was also discussed at Help talk:Citation Style 1/Archive 74 § DOI encoding.
- —Trappist the monk (talk) 13:33, 7 December 2021 (UTC)
- The example doi in this discussion was once a working identifier (with the space); it still works to some extent because you don't get the doi.org error page but rather you get a 404 error at science.org. I expect that that doi has been replaced with something else. Regardless, it is doubtful that the interwikilink form (
- It might be better to give an example that has the possibility of linking to a valid DOI. – Jonesey95 (talk) 03:14, 7 December 2021 (UTC)
- I am not sure anything can be done about this but it should probably be noted that this also fails with interwikilinks, e.g.: doi:10.1126/science. 1140516 renders the link with an underscore instead of a space. —Uzume (talk) 01:45, 7 December 2021 (UTC)
doi-access=free
[edit]I have hacked the sandbox to use {{catalog lookup link}}
so that the doi identifier can be marked as free-to-read in the same way that a free-to-read doi in a cs1|2 template can be marked: |doi-access=free
. The Template:doi/testcases failures are not really failures. The live version of this template does not trim whitespace from the doi so the leading whitespace in {{{1}}}
(test 2) appears in the final rendering but {{catalog lookup link}}
does trim whitespace so the whitespace is not rendered.
The sandbox version of this template supports the cs1|2 free
access indicator which is accomplished by template styles so the sandbox rendering includes the necessary template styles stripmarker:
{{doi/sandbox|10.5194/essd-12-2013-2020}}
'"`UNIQ--templatestyles-0000002C-QINU`"'[[doi (identifier)|doi]]:[https://doi.org/10.5194%2Fessd-12-2013-2020 10.5194/essd-12-2013-2020]
I may tweak {{catalog lookup link}}
to suppress the template styles when an access icon is not required...
Using |doi-access=free
(no other value supported):
{{doi/sandbox|10.5194/essd-12-2013-2020|doi-access=free}}
'"`UNIQ--templatestyles-00000030-QINU`"'[[doi (identifier)|doi]]:<span class="id-lock-free" title="Freely accessible">[https://doi.org/10.5194%2Fessd-12-2013-2020 10.5194/essd-12-2013-2020]</span>
Without objection, I shall update the live template.
—Trappist the monk (talk) 14:17, 10 August 2022 (UTC)
- There having been no objection, updated.
- —Trappist the monk (talk) 13:23, 18 August 2022 (UTC)
id as alias for unnamed first parameter
[edit]It is requested that an edit be made to the template-protected template at Template:Doi. (edit · history · last · links · sandbox · edit sandbox · sandbox history · sandbox last edit · sandbox diff · test cases · transclusion count · protection log) This template must be followed by a complete and specific description of the request, so that an editor unfamiliar with the subject matter could complete the requested edit immediately.
Edit requests to template-protected pages should only be used for edits that are either uncontroversial or supported by consensus. If the proposed edit might be controversial, discuss it on the protected page's talk page before using this template. Consider making changes first to the template's sandbox and test them thoroughly here before submitting an edit request. To request that a page be protected or unprotected, make a protection request. When the request has been completed or denied, please add the |
I have edited Template:doi/sandbox to remove id as an alias for the unnamed first parameter. The template currently displays correctly when given the |id=
parameter instead of an unnamed first parameter, but still places the page in Category:Pages with DOI errors. That category does not currently have any items in it using |id=
. After this edit is made, pages will still be placed in that maintenance category, but will not display as expected. Daask (talk) 19:29, 18 January 2025 (UTC)
- Would it not make more sense to have
|id=
not trigger the category, rather than having extant uses of it be incorrect? Primefac (talk) 13:03, 24 January 2025 (UTC)