Uniform Resource Locator: Unterschied zwischen den Versionen

Aus Foxwiki
Die Seite wurde neu angelegt: „'''topic''' - Kurzbeschreibung == Beschreibung == == Installation == == Syntax == === Optionen === === Parameter === === Umgebungsvariablen === === Exit-Status === == Anwendung == === Fehlerbehebung === == Konfiguration == === Dateien === == Anhang == === Siehe auch === ==== Unterseiten ==== {{Special:PrefixIndex/{{BASEPAGENAME}}}} ==== Sicherheit ==== ==== Dokumentation ==== ===== RFC ===== ===== Man-Pages ===== ===== Info-Pages ===== ==== Links ==== ===…“
 
Keine Bearbeitungszusammenfassung
 
(42 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
'''topic''' - Kurzbeschreibung
'''Uniform Resource Locator''' - URL
 
== Beschreibung ==
== Beschreibung ==
== Installation ==
[[File:url01.png|mini|400px]]
== Syntax ==
Ein '''Uniform Resource Locator''' (Abk. '''URL'''; {{enS}} für ''einheitlicher [[Ressource#Informatik|Ressourcenzeiger]]'') identifiziert und lokalisiert eine Ressource, beispielsweise eine [[Webseite]], über die zu verwendende Zugriffsmethode (zum Beispiel das verwendete [[Netzwerkprotokoll]] wie [[Hypertext Transfer Protocol|HTTP]] oder [[File Transfer Protocol|FTP]]) und den Ort (engl. location) der Ressource in [[Rechnernetz|Computernetzwerken]]
=== Optionen ===
* Der ursprüngliche Standard wurde im Dezember 1994 als RFC 1738 publiziert, er ist inzwischen durch die Veröffentlichung mehrerer anderer [[Request for Comments|RFCs]] obsolet
=== Parameter ===
=== Umgebungsvariablen ===
=== Exit-Status ===
== Anwendung ==
=== Fehlerbehebung ===
== Konfiguration ==
=== Dateien ===
== Anhang ==
=== Siehe auch ===
==== Unterseiten ====
{{Special:PrefixIndex/{{BASEPAGENAME}}}}
==== Sicherheit ====
==== Dokumentation ====
===== RFC =====
===== Man-Pages =====
===== Info-Pages =====
==== Links ====
===== Einzelnachweise =====
<references />
===== Projekt =====
===== Weblinks =====
<noinclude>
=== Testfragen ===
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 1''
<div class="mw-collapsible-content">'''Antwort1'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 2''
<div class="mw-collapsible-content">'''Antwort2'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 3''
<div class="mw-collapsible-content">'''Antwort3'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 4''
<div class="mw-collapsible-content">'''Antwort4'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 5''
<div class="mw-collapsible-content">'''Antwort5'''</div>
</div>


= TMP =
URLs sind eine Unterart der generellen Identifikationsbezeichnung mittels [[Uniform Resource Identifier]]n (URIs)
{{Weiterleitungshinweis|URL|Zu weiteren Bedeutungen siehe [[Url]].}}
* Da URLs die erste und häufigste Art von URIs darstellen, werden die Begriffe häufig [[Synonymie|synonym]] verwendet
Ein '''Uniform Resource Locator''' (Abk. '''URL'''; {{enS}} für ''einheitlicher [[Ressource#Informatik|Ressourcenzeiger]]'') identifiziert und lokalisiert eine Ressource, beispielsweise eine [[Webseite]], über die zu verwendende Zugriffsmethode (zum Beispiel das verwendete [[Netzwerkprotokoll]] wie [[Hypertext Transfer Protocol|HTTP]] oder [[File Transfer Protocol|FTP]]) und den Ort (engl. {{lang|en|''location''}}) der Ressource in [[Rechnernetz|Computernetzwerken]]. Der ursprüngliche Standard wurde im Dezember 1994 als RFC 1738 publiziert, er ist inzwischen durch die Veröffentlichung mehrerer anderer [[Request for Comments|RFCs]] obsolet. Die aktuellen RFCs sind (Stand 2023):
* Im allgemeinen Sprachgebrauch werden URLs auch als '''Internetadresse''' oder '''Webadresse''' bezeichnet, folgend) meist speziell URLs von [[Webseite]]n gemeint sind
 
* {{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax}}
** {{RFC-Internet |RFC=6874 |Titel=Representing IPv6 Zone Identifiers in Address Literals and Uniform Resource Identifiers}}
** {{RFC-Internet |RFC=8820 |Titel=URI Design and Ownership}}
* {{RFC-Internet |RFC=4248 |Titel=The telnet URI Scheme}}
* {{RFC-Internet |RFC=4266 |Titel=The gopher URI Scheme}}
* {{RFC-Internet |RFC=6068 |Titel=The ‘mailto’ URI Scheme}}
* {{RFC-Internet |RFC=6196 |Titel=Moving mailserver: URI Scheme to Historic}}
* {{RFC-Internet |RFC=6270 |Titel=The ‘tn3270’ URI Scheme}}
* {{RFC-Internet |RFC=8089 |Titel=The "file" URI Scheme}}
 
 
URLs sind eine Unterart der generellen Identifikationsbezeichnung mittels [[Uniform Resource Identifier]]n (URIs). Da URLs die erste und häufigste Art von URIs darstellen, werden die Begriffe häufig [[Synonymie|synonym]] verwendet. Im allgemeinen Sprachgebrauch werden URLs auch als '''Internetadresse''' oder '''Webadresse''' bezeichnet,<ref>Duden – ''Deutsches Universalwörterbuch.'' 6. Auflage.</ref> wobei damit (der umgangssprachlich häufigen Gleichsetzung von [[Internet]] und [[World Wide Web|WWW]]<ref>{{Internetquelle |url=http://www.news.de/medien/855030425/internet-und-world-wide-web-der-unterschied/1/ |titel=Internet und World Wide Web – der Unterschied |hrsg=News.de |datum=2009-10-29 |abruf=2010-12-11}}</ref> folgend) meist speziell URLs von [[Webseite]]n gemeint sind.


== Aufbau ==
== Aufbau ==
Der grundsätzliche URL-Aufbau besteht aus einer die Zugriffsmethode festlegenden Schema-Bezeichnung (englisch ''scheme'') und einem Schema-spezifischen Teil ''(scheme-specific part)'', die durch einen Doppelpunkt getrennt sind:
Der grundsätzliche URL-Aufbau besteht aus einer die Zugriffsmethode festlegenden Schema-Bezeichnung (englisch ''scheme'') und einem Schema-spezifischen Teil ''(scheme-specific part)'', die durch einen Doppelpunkt getrennt sind:
<pre>
<scheme>:<scheme-specific-part>
<scheme>:<scheme-specific-part>
</pre>


=== Schema ''(scheme)'' ===
=== Schema ===
Legt fest, mit welcher technischen Methode die Ressource angesprochen werden soll.<ref name="rfc3986_3_1" /> Ist meistens, aber nicht zwingend gleichlautend mit dem verwendeten [[Netzwerkprotokoll]], über das die Ressource lokalisiert werden kann. Beispiele sind:
; Schema ''(scheme)''
Legt fest, mit welcher technischen Methode die Ressource angesprochen werden soll. Ist meistens, aber nicht zwingend gleichlautend mit dem verwendeten [[Netzwerkprotokoll]], über das die Ressource lokalisiert werden kann
* Beispiele sind:


* mit gleich lautendem Protokoll: <code>[[Hypertext Transfer Protocol|http]]</code>, <code>[[Hypertext Transfer Protocol Secure|https]]</code> oder <code>[[File Transfer Protocol|ftp]]</code>
* mit gleich lautendem Protokoll: <code>[[Hypertext Transfer Protocol|http]]</code>, <code>[[Hypertext Transfer Protocol Secure|https]]</code> oder <code>[[File Transfer Protocol|ftp]]</code>
* mit anderem Protokoll: <code>[[mailto]]</code><ref name="mailto_scheme" /> (zum Schreiben einer E-Mail) oder <code>file</code><ref name="file_scheme" /> (zum Zugriff auf lokale Dateien).
* mit anderem Protokoll: <code>[[mailto]]</code> zum Schreiben einer E-Mail) oder <code>file</code> (zum Zugriff auf lokale Dateien)


=== Schema-spezifischer Teil ''(scheme-specific part)'' ===
=== Schema-spezifischer Teil ===
Je nach Schema sind unterschiedliche spezifische Angaben erforderlich und möglich. In den meisten Fällen beginnt er mit der Zeichenkette <code>//</code>, jedoch ist bei manchen Varianten auch lediglich der Doppelpunkt definiert. Die folgenden Beispiele beziehen sich auf das Hypertext Transfer Protocol (HTTP).
; Schema-spezifischer Teil ''(scheme-specific part)''
Je nach Schema sind unterschiedliche spezifische Angaben erforderlich und möglich
* In den meisten Fällen beginnt er mit der Zeichenkette <code>//</code>, jedoch ist bei manchen Varianten auch lediglich der Doppelpunkt definiert
* Die folgenden Beispiele beziehen sich auf das Hypertext Transfer Protocol (HTTP)


==== Benutzer und Kennwort ''(user, password)'' ====
==== Benutzer/Kennwort ====
Falls benötigt, können [[Login (Informationstechnik)|Login]]-Informationen aus [[Nickname|Benutzername]] ''(user)'' und [[Kennwort]] ''(password)'' mit übermittelt werden.<ref name="rfc3986_3_2_1" /> Diese werden, voneinander durch Doppelpunkt getrennt, dem Host mit einem trennenden At-Zeichen ([[@]]) vorangestellt.
; Benutzer und Kennwort ''(user, password)''
Falls benötigt, können [[Login (Informationstechnik)|Login]]-Informationen aus [[Nickname|Benutzername]] ''(user)'' und [[Kennwort]] ''(password)'' mit übermittelt werden. Diese werden, voneinander durch Doppelpunkt getrennt, dem Host mit einem trennenden At-Zeichen ([[@]]) vorangestellt


Auch wenn für dieses Beispiel das Protokoll [[Hypertext Transfer Protocol|HTTP]] gewählt wurde, ist die Angabe von Benutzername und Kennwort als Teil des URLs ''nicht'' Teil der HTTP-Spezifikation!<ref>{{RFC-Internet |RFC=2616 |Titel=Hypertext Transfer Protocol |Datum= |Abschnitt=3.2.2 |Abschnittstitel=http URL|Standard=HTTP/1.1}}</ref> Aktuelle Browser akzeptieren diese URL-Syntax zwar, fragen aber beim Benutzer nach, ob er sich wirklich mit den angegebenen Daten anmelden möchte. Der [[Internet Explorer]]&nbsp;6 (ab Windows XP SP2) und neuere Versionen fallen hier aus dem Rahmen, indem sie diese URL-Syntax rundweg als fehlerhaft ablehnen. Mit einem [[Windows-Registrierungsdatenbank|Registry]]-Eintrag kann man sie zum gleichen Verhalten zwingen, wie es die Vorgänger bis Version 5.5 zeigen: Diese übernehmen die Anmeldedaten ungefragt und übergeben sie direkt an den Server.
Auch wenn für dieses Beispiel das Protokoll [[Hypertext Transfer Protocol|HTTP]] gewählt wurde, ist die Angabe von Benutzername und Kennwort als Teil des URLs ''nicht'' Teil der HTTP-Spezifikation! Aktuelle Browser akzeptieren diese URL-Syntax zwar, fragen aber beim Benutzer nach, ob er sich wirklich mit den angegebenen Daten anmelden möchte
* Der [[Internet Explorer]]&nbsp;6 (ab Windows XP SP2) und neuere Versionen fallen hier aus dem Rahmen, indem sie diese URL-Syntax rundweg als fehlerhaft ablehnen
* Mit einem [[Windows-Registrierungsdatenbank|Registry]]-Eintrag kann man sie zum gleichen Verhalten zwingen, wie es die Vorgänger bis Version 5.5 zeigen: Diese übernehmen die Anmeldedaten ungefragt und übergeben sie direkt an den Server


Bei einigen anderen Protokollen, etwa [[File Transfer Protocol|FTP]], ist die Angabe der Benutzerdaten in der gezeigten Form dagegen völlig korrekt und durch die Standards abgedeckt.
Bei einigen anderen Protokollen, etwa [[File Transfer Protocol|FTP]], ist die Angabe der Benutzerdaten in der gezeigten Form dagegen völlig korrekt und durch die Standards abgedeckt


==== Host ====
==== Host ====
Die Host-Komponente wird in Form einer [[IPv4]]-Adresse in [[Dezimalsystem|dezimaler]] Schreibweise durch Punkte getrennt, in Form einer [[IPv6]]-Adresse in [[Hexadezimalsystem|hexadezimaler]] Schreibweise durch Doppelpunkte getrennt und in eckige Klammern gesetzt oder in Form eines [[Domain (Internet)|FQDN]] notiert.<ref name="rfc3986_3_2_2" />
Die Host-Komponente wird in Form einer [[IPv4]]-Adresse in [[Dezimalsystem|dezimaler]] Schreibweise durch Punkte getrennt, in Form einer [[IPv6]]-Adresse in [[Hexadezimalsystem|hexadezimaler]] Schreibweise durch Doppelpunkte getrennt und in eckige Klammern gesetzt oder in Form eines [[Domain (Internet)|FQDN]] notiert


==== Port ====
==== Port ====
Die Angabe des [[Port (Protokoll)|Ports]] erlaubt die Ansteuerung eines [[Transmission Control Protocol|TCP]]-Ports. Wird kein Port angegeben, so wird der Standard-Port des jeweiligen Protokolls verwendet – zum Beispiel bei HTTP 80, bei HTTPS 443 und bei FTP 21.<ref name="rfc3986_3_2_3" />
Die Angabe des [[Port (Protokoll)|Ports]] erlaubt die Ansteuerung eines [[Transmission Control Protocol|TCP]]-Ports
* Wird kein Port angegeben, so wird der Standard-Port des jeweiligen Protokolls verwendet – zum Beispiel bei HTTP 80, bei HTTPS 443 und bei FTP 21


==== Pfad ''(Path)'' ====
==== Pfad ====
Der Pfad beschreibt eine bestimmte Ressource (diese kann sich beispielsweise mit der Verzeichnisstruktur des Zielsystems decken, also etwa eine Datei oder ein Verzeichnis) auf dem [[Server (Software)|Server]].<ref name="rfc3986_3_3" /> Der Pfad kann auch leer sein. Ein leerer Pfad kann optional durch einen Slash ersetzt werden und ist zu diesem gleichbedeutend.
; Schema ''(scheme)''
Der Pfad beschreibt eine bestimmte Ressource (diese kann sich beispielsweise mit der Verzeichnisstruktur des Zielsystems decken, also etwa eine Datei oder ein Verzeichnis) auf dem [[Server (Software)|Server]]. Der Pfad kann auch leer sein
* Ein leerer Pfad kann optional durch einen Slash ersetzt werden und ist zu diesem gleichbedeutend


Die Interpretation ([[Datei]] oder [[Verzeichnisstruktur|Verzeichnis]]; Textdatei liefern oder [[Skriptsprache|Skript]] ausführen) bleibt dem Server überlassen. Ein typisches Beispiel für die Interpretationsfreiheit ist das Verhalten bei der Anforderung des Pfades <code>/</code> durch einen Client: Je nach Einstellung liefert der Server etwa den Inhalt einer namentlich ausgezeichneten Datei (wie <code>/index.html</code>, <code>/README</code>, <code>/HEADER</code>), ohne dass dies für den anfragenden Client ersichtlich ist. Genauso kann der Server allerdings –&nbsp;je nach Protokoll&nbsp;– auch explizit zu dieser Ressource weiterleiten oder eine Verzeichnisauflistung ausgeben.
Die Interpretation ([[Datei]] oder [[Verzeichnisstruktur|Verzeichnis]]; Textdatei liefern oder [[Skriptsprache|Skript]] ausführen) bleibt dem Server überlassen
* Ein typisches Beispiel für die Interpretationsfreiheit ist das Verhalten bei der Anforderung des Pfades <code>/</code> durch einen Client: Je nach Einstellung liefert der Server etwa den Inhalt einer namentlich ausgezeichneten Datei (wie <code>/index.html</code>, <code>/README</code>, <code>/HEADER</code>), ohne dass dies für den anfragenden Client ersichtlich ist
* Genauso kann der Server allerdings –&nbsp;je nach Protokoll&nbsp;– auch explizit zu dieser Ressource weiterleiten oder eine Verzeichnisauflistung ausgeben


==== Abfrage ''(Query)'' ====
==== Abfrage ====
{{Hauptartikel|Query-String}}
; Abfrage ''(Query)''
Im Fall des HTTP kann nach dem eigentlichen Ressourcenzeiger –&nbsp;getrennt durch ein [[Fragezeichen]]&nbsp;– ein Query-String folgen.<ref name="rfc3986_3_4" /> Damit können zusätzliche Informationen übertragen werden, die server- oder clientseitig weiterverarbeitet werden können.
[[Query-String]]
Im Fall des HTTP kann nach dem eigentlichen Ressourcenzeiger –&nbsp;getrennt durch ein [[Fragezeichen]]&nbsp;– ein Query-String folgen. Damit können zusätzliche Informationen übertragen werden, die server- oder clientseitig weiterverarbeitet werden können


==== Fragment ====
==== Fragment ====
{{Hauptartikel|Fragmentbezeichner}}
[[Fragmentbezeichner]]
Nach einem [[Doppelkreuz (Schriftzeichen)|Doppelkreuz]] kann ein Teil der Ressource referenziert werden, typischerweise ein [[Anker (HTML)|Anker]] in einer HTML-Seite, zu dem nach dem Aufrufen der Seite automatisch [[Bildlauf|hinuntergescrollt]] wird:<ref name="rfc3986_3_5" /> Der URL <code><nowiki>http://example.com/dokument.html#absatz3</nowiki></code> würde, in dem hier fiktiven Dokument, den Browser dazu veranlassen, zum Anfang des dritten Absatzes zu scrollen.
Nach einem [[Doppelkreuz (Schriftzeichen)|Doppelkreuz]] kann ein Teil der Ressource referenziert werden, typischerweise ein [[Anker (HTML)|Anker]] in einer HTML-Seite, zu dem nach dem Aufrufen der Seite automatisch [[Bildlauf|hinuntergescrollt]] wird: Der URL <code><nowiki>http://example.com/dokument.html#absatz3</nowiki></code> würde, in dem hier fiktiven Dokument, den Browser dazu veranlassen, zum Anfang des dritten Absatzes zu scrollen


=== Beispiele ===
=== Beispiele ===
Für <code>http(s)</code>:
; Für <code>http(s)</code>
<pre>
<pre>
      |-------------------- Schema-spezifischer Teil ----------------------|
|-------------------- Schema-spezifischer Teil ----------------------|
      |                                                                   |
| |
https://maxmuster:geheim@www.example.com:8080/index.html?p1=A&p2=B#ressource
https://maxmuster:geheim@www.example.com:8080/index.html?p1=A&p2=B#ressource
\___/   \_______/ \____/ \_____________/ \__/\_________/ \_______/ \_______/
\___/ \_______/ \____/ \_____________/ \__/\_________/ \_______/ \_______/
  |         |       |           |         |       |         |         |
| | | | | | | |
Schema¹ Benutzer Kennwort     Host     Port   Pfad     Query   Fragment
Schema¹ Benutzer Kennwort Host Port Pfad Query Fragment
</pre>
</pre>


¹ hier gleich Netzwerkprotokoll
¹ hier gleich Netzwerkprotokoll


Für <code>mailto</code>:
; Für <code>mailto</code>
<pre>
<pre>
mailto:max@example.org
mailto:max@example.org
\____/ \_____________/
\____/ \_____________/
  |         |
| |
Schema²       |
Schema² |
        E-Mail-Adresse gemäß RFC 5322
E-Mail-Adresse gemäß RFC 5322
</pre>
</pre>


² hier kein Netzwerkprotokoll
² hier kein Netzwerkprotokoll


Für <code>news</code> (in diesem Beispiel ist weder ein Netzwerkprotokoll noch eine Host-Adresse enthalten):
; Für <code>news</code> (in diesem Beispiel ist weder ein Netzwerkprotokoll noch eine Host-Adresse enthalten)
<pre>
<pre>
  news:alt.hypertext
  news:alt.hypertext
  \__/ \___________/
  \__/ \___________/
  |       |
| |
Schema     |
Schema |
      Name der Newsgroup
Name der Newsgroup
</pre>
</pre>


Für <code>file</code>:
; Für <code>file</code>
<pre>
<pre>
  file:///verzeichnis/unterverzeichnis/datei
  file:///verzeichnis/unterverzeichnis/datei
  \__/   \_________________________________/
  \__/ \_________________________________/
  |                   |
| |
Schema                 |
Schema |
      Pfad zu einer lokalen Datei im Dateisystem des Rechners, der den URL interpretiert
Pfad zu einer lokalen Datei im Dateisystem des Rechners, der den URL interpretiert
</pre>
</pre>
Streng genommen hat das <code>file</code>-Schema die Form <code>file://&lt;host>/<path></code>, wobei aber der Host-Teil praktisch nicht verwendet wird, da das <code>file</code>-Schema mangels einer Möglichkeit, ein Netzwerkprotokoll für den Zugriff auf die Datei anzugeben, kaum sinnvoll über ein Netzwerk benutzt werden kann.<ref name="rfc_1738_3_10">{{RFC-Internet |RFC=1738 |Titel=Uniform Resource Locators (URL) |Abschnitt=3.10 |Abschnittstitel=FILES |Datum=1994-12}}</ref>
File-URLs werden beispielsweise in der Programmiersprache [[Java (Programmiersprache)|Java]] verwendet, um auf diese Weise auf lokale Dateien zuzugreifen.<ref>{{Internetquelle |url=http://download.oracle.com/javase/1.5.0/docs/api/java/io/File.html |titel=Class File (Java 1.5.0 API) |hrsg=[[Oracle]] |abruf=2010-12-11}}</ref> Je nach Browser ist oftmals das Öffnen von <code>file</code>-Links nur nach spezieller clientseitiger Konfiguration oder unter Zuhilfenahme von [[Addon|AddOns]] etc. möglich.<ref>''[[:en:File URI scheme #Browser behaviour|File URI scheme #Browser behaviour]]'' in der englischsprachigen Wikipedia</ref><ref>Firefox beispielsweise blockiert aus Sicherheitsgründen seit 2012 alle lokalen Zugriffe mit <code>file:</code>, wenn das umgebende Dokument aus <code>http&#58;//</code> stammt.</ref>


=== Konkrete Beispiele ===
Streng genommen hat das <code>file</code>-Schema die Form <code>file://&lt;host>/<path></code>, wobei aber der Host-Teil praktisch nicht verwendet wird, da das <code>file</code>-Schema mangels einer Möglichkeit, ein Netzwerkprotokoll für den Zugriff auf die Datei anzugeben, kaum sinnvoll über ein Netzwerk benutzt werden kann
File-URLs werden beispielsweise in der Programmiersprache [[Java (Programmiersprache)|Java]] verwendet, um auf diese Weise auf lokale Dateien zuzugreifen. Je nach Browser ist oftmals das Öffnen von <code>file</code>-Links nur nach spezieller clientseitiger Konfiguration oder unter Zuhilfenahme von [[Addon|AddOns]] etc. möglich
 
; Konkrete Beispiele
* <code><nowiki>ftp://max:muster@ftp.example.com</nowiki></code> … [[File Transfer Protocol|FTP]] mit Benutzer und Kennwort
* <code><nowiki>ftp://max:muster@ftp.example.com</nowiki></code> … [[File Transfer Protocol|FTP]] mit Benutzer und Kennwort
* <code><nowiki>http://de.wikipedia.org</nowiki></code> … [[Website]] ohne Pfad (Aufruf der [[Homepage|Startseite]])
* <code><nowiki>http://de.wikipedia.org</nowiki></code> … [[Website]] ohne Pfad (Aufruf der [[Homepage|Startseite]])
Zeile 161: Zeile 119:
* <code><nowiki>file:///foo/bar.txt</nowiki></code> … Zugriff auf eine lokale Datei
* <code><nowiki>file:///foo/bar.txt</nowiki></code> … Zugriff auf eine lokale Datei


== Relative URLs ==
=== Relative URLs ===
Neben den bisher dargestellten absoluten oder vollständigen URLs gibt es auch relative URLs.<ref>{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Datum=2005-01 |Abschnitt=4.2 |Abschnittstitel=Relative Reference}}</ref> Sie sind nur innerhalb eines Kontextes gültig, von dem sie Eigenschaften erben. Ihnen fehlt die Ortsangabe im [[World Wide Web]] oder einem echten [[Intranet]]. Sie sind vor allem in der Gruppe http, https und ftp möglich, aber auch bei mailto. Das entspräche einer Telefonnummer ohne [[Telefonvorwahl|Vorwahl]] (des Landes, des [[Ortsnetz]]es).
Neben den bisher dargestellten absoluten oder vollständigen URLs gibt es auch relative URLs. Sie sind nur innerhalb eines Kontextes gültig, von dem sie Eigenschaften erben
* Ihnen fehlt die Ortsangabe im [[World Wide Web]] oder einem echten [[Intranet]]
* Sie sind vor allem in der Gruppe http, https und ftp möglich, aber auch bei mailto
* Das entspräche einer Telefonnummer ohne [[Telefonvorwahl|Vorwahl]] (des Landes, des [[Ortsnetz]]es)


{| class="wikitable"
{| class="wikitable"
Zeile 185: Zeile 146:
|-
|-
| <code>../</code> || ein [[Verzeichnisstruktur|Pfad-Segment]] aufwärts
| <code>../</code> || ein [[Verzeichnisstruktur|Pfad-Segment]] aufwärts
|rowspan="2"| Ein Server muss keine durch <code>/</code> gegliederte Pfad-Segmentierung unterstützen.
|rowspan="2"| Ein Server muss keine durch <code>/</code> gegliederte Pfad-Segmentierung unterstützen
|rowspan="2"| <code>/pfad/zur/../zur/datei<br />./relativer/pfad</code>
|rowspan="2"| <code>/pfad/zur/../zur/datei<br />./relativer/pfad</code>
|-
|-
Zeile 191: Zeile 152:
|}
|}


Relative URLs werden oft eingesetzt, um eine Gruppe zusammengehörender Ressourcen wahlweise in einem lokalen [[Dateisystem]] oder an unterschiedlichen Orten in verschiedenen Netzwerk-Domänen unverändert abzulegen und aufeinander zu verlinken. Im Übrigen ist die Interpretation des Identifikators (Zeichenkette zwischen <code>host:port</code> und <code>#</code>) jedem Server freigestellt – zwar handhabt es die weitaus überwiegende Anzahl der Server und jede Standard-Software wie oben angegeben, jedoch können <code>/</code> genau wie <code>? %&nbsp;&</code> nach eigenen Regeln ausgewertet werden.
Relative URLs werden oft eingesetzt, um eine Gruppe zusammengehörender Ressourcen wahlweise in einem lokalen [[Dateisystem]] oder an unterschiedlichen Orten in verschiedenen Netzwerk-Domänen unverändert abzulegen und aufeinander zu verlinken
* Im Übrigen ist die Interpretation des Identifikators (Zeichenkette zwischen <code>host:port</code> und <code>#</code>) jedem Server freigestellt – zwar handhabt es die weitaus überwiegende Anzahl der Server und jede Standard-Software wie oben angegeben, jedoch können <code>/</code> genau wie <code>? %&nbsp;&</code> nach eigenen Regeln ausgewertet werden


Bei <code>mailto:</code> wäre eine relative URL <code>mailto:<nowiki />Nachbar</code> (ohne&nbsp;<code>@</code>)&nbsp;– sie gilt nur im lokalen Netzwerk.
Bei <code>mailto:</code> wäre eine relative URL <code>mailto:<nowiki />Nachbar</code> (ohne&nbsp;<code>@</code>)&nbsp;– sie gilt nur im lokalen Netzwerk


== Liste erlaubter Zeichen ==
== Zeichensatz ==
Reservierte Zeichen sind:
{| class="wikitable options"
 
| Reservierte Zeichen || Sonderzeichen ||  / ? # [ ] @ : & ' ( ) * + , ; =
* Sonderzeichen <code>/ ? # [ ] @ : $ & ' ( ) * + , ; =</code>
|-
 
| Nicht reservierte Zeichen || Buchstaben ||  A–Z, a–z
Nicht reservierte Zeichen sind:
|-
 
| || Ziffern || 0–9
* Buchstaben <code>A–Z, a–z</code>
|-
* Ziffern <code>0–9</code>
| || Sonderzeichen || - . _ ~
* Sonderzeichen <code>- . _ ~</code>
|}
 
In bestimmten Fällen ist außerdem das Leerzeichen <code>␣</code> (dieses alternativ auch mit <code>+</code><ref name="SO-URL-Encoding" /> oder <code>%</code>) in [[URL-Encoding|Prozentkodierung]] (<code>%20</code>) darzustellen.<ref name="W3-School" />


== Sprachgebrauch ==
; Leerzeichen
Im deutschen Sprachgebrauch hat ''URL'' häufig den weiblichen [[Artikel (Wortart)|Artikel]], wird aber auch mit männlichem Artikel verwendet.<ref>Duden – ''Deutsches Universalwörterbuch'', siehe auch [http://www.duden.de/suche/?suchwort=URL&suchbereich=mixed&btnSearch.x=0&btnSearch.y=0 duden.de]</ref> Die Wahl des Genus hängt davon ab, ob es in Anlehnung an die deutsche Übersetzung ''die Adresse'' (feminin) gebildet wird oder mittels der Grammatikregel, dass Hauptwörter auf ''-or'' (hier ''Locator'' oder ''-identifikator'') oder ''-er'' (''-bezeichner'', ''-lokalisierer'', ''-anzeiger'') im Deutschen stets maskulin sind.<ref>{{cite web|url=http://www.korrekturen.de/forum/index.cgi/read/70|title=korrekturen.de – Forum – Der/die URL – Der/das (Werbe)Banner|work=korrekturen.de}}</ref>
In bestimmten Fällen ist außerdem das Leerzeichen <code>␣</code> (dieses alternativ auch mit <code>+</code> oder <code>%</code>) in [[URL-Encoding|Prozentkodierung]] (<code>%20</code>) darzustellen


== URLs in Texten ==
== URLs in Texten ==
Anhang&nbsp;C von RFC 3986 empfiehlt, URIs (und damit auch URLs) in Texten
Anhang&nbsp;C von RFC 3986 empfiehlt, URIs (und damit auch URLs) in Texten


* eigenständig auf einer Zeile,
* eigenständig auf einer Zeile
* mit doppelten Anführungsstrichen <code>"<nowiki>http://example.com/</nowiki>"</code> oder
* mit doppelten Anführungsstrichen <code>"<nowiki>http://example.com/</nowiki>"</code> oder
* mit spitzen Klammern <code>&lt;<nowiki>http://example.com/</nowiki>&gt;</code>
* mit spitzen Klammern <code>&lt;<nowiki>http://example.com/</nowiki>&gt;</code>


gegen den Kontext und vor allem gegen die [[Satzzeichen|Interpunktion]] des Satzes abzugrenzen.
gegen den Kontext und vor allem gegen die [[Satzzeichen|Interpunktion]] des Satzes abzugrenzen


== URLs und Suchmaschinen ==
== URLs und Suchmaschinen ==
Auch wenn URLs technisch komplex aufgebaut sein können, können schlecht gestaltete URLs die Auffindbarkeit von Inhalten durch Suchmaschinen behindern. Aus diesem Grund empfiehlt der Suchmaschinenbetreiber Google z.&nbsp;B. den bedachten Einsatz von Parametern in URLs.<ref>{{Internetquelle |url=https://developers.google.com/search/docs/advanced/guidelines/url-structure?hl=de |titel=URL-Struktur einfach halten |abruf=2021-02-25 |sprache=de}}</ref> Google hat auch die Begrifflichkeit der [[Canonical Link|kanonischen URL]] eingeführt. Eine kanonische URL ist demnach die URL der Seite, von der Google annimmt, dass sie die repräsentativste von mehrfachen Verweisen auf einer Website ist. Aus Sicht einer Suchmaschine sind z.&nbsp;B. die URL-Varianten <code>"<nowiki>http://www.example.com/</nowiki>" , "<nowiki>http://example.com/</nowiki>" , "<nowiki>https://www.example.com/</nowiki>" und "<nowiki>https://example.com/</nowiki>"</code>vier eigenständige Versionen, die – wenn keine kanonische URL definiert ist – zu "Duplicate-Content" und damit einer suboptimalen Sichtbarkeit führen können.
Da URLs komplex aufgebaut sein können, können schlecht gestaltete URLs die Auffindbarkeit von Inhalten durch Suchmaschinen behindern
* Aus diesem Grund empfiehlt der Suchmaschinenbetreiber Google z.&nbsp;B.&nbsp;
* den bedachten Einsatz von Parametern in URLs. Google hat auch die Begrifflichkeit der [[Canonical Link|kanonischen URL]] eingeführt
* Eine kanonische URL ist demnach die URL der Seite, von der Google annimmt, dass sie die repräsentativste von mehrfachen Verweisen auf einer Website ist
* Aus Sicht einer Suchmaschine sind z.&nbsp;B.&nbsp;
* die URL-Varianten <code>"<nowiki>http://www.example.com/</nowiki>" , "<nowiki>http://example.com/</nowiki>" , "<nowiki>https://www.example.com/</nowiki>" und "<nowiki>https://example.com/</nowiki>"</code>vier eigenständige Versionen, die – wenn keine kanonische URL definiert ist – zu "Duplicate-Content" und damit einer suboptimalen Sichtbarkeit führen können


Die Prüfung der URL-Struktur wird oft im Rahmen der sogenannten [[Suchmaschinenoptimierung]] durchgeführt.
Die Prüfung der URL-Struktur wird oft im Rahmen der sogenannten [[Suchmaschinenoptimierung]] durchgeführt


== Geschichte ==
== Geschichte ==
=== Name und Standardisierung ===
=== Name und Standardisierung ===
In der Anfangszeit des WWW (ab Ende 1990) fand sich in der Dokumentation auf <code>info.cern.ch</code> zunächst keine dedizierte Bezeichnung für die Adressierung von Webseiten, das Thema wurde nur beschreibend als „W3&nbsp;document address“, „W3&nbsp;name“, „W3&nbsp;address“ oder „Hypertext Name“ dokumentiert.<ref>{{Internetquelle |url=http://www.w3.org/History/19921103-hypertext/hypertext/WWW/Technical.html |titel=Technical details |hrsg=CERN / W3C |datum=1992-11-13 |abruf=2010-12-22}}</ref><ref name="w3_naming_schemes">{{Internetquelle |url=http://www.w3.org/History/19921103-hypertext/hypertext/WWW/Addressing/Addressing.html |titel=W3 Naming Schemes |hrsg=CERN / W3C |datum=1992-02-24 |abruf=2010-12-22}}</ref><ref>{{Internetquelle |url=http://www.w3.org/History/19921103-hypertext/hypertext/WWW/Addressing/BNF.html |titel=W3 address syntax: BNF |hrsg=CERN / W3C |datum=1992-06-29 |abruf=2010-12-22}}</ref> Die damals spezifizierte (und in den ersten Webseiten verwendete) Gestalt der Adressierung entspricht aber schon der später als „URL“ standardisierten Form; im Standardisierungsprozess wurden zwar Änderungen erwogen, wegen der inzwischen schon fortgeschrittenen Verbreitung des WWW aber wieder verworfen.<ref name="w3_naming_schemes" /><ref name="Berners-Lee. 1999, S. 63">Berners-Lee 1999, S. 63.</ref>
In der Anfangszeit des WWW (ab Ende 1990) fand sich in der Dokumentation auf <code>info.cern.ch</code> zunächst keine dedizierte Bezeichnung für die Adressierung von Webseiten, das Thema wurde nur beschreibend als „W3&nbsp;document address“, „W3&nbsp;name“, „W3&nbsp;address“ oder „Hypertext Name“ dokumentiert
Die damals spezifizierte (und in den ersten Webseiten verwendete) Gestalt der Adressierung entspricht aber schon der später als „URL“ standardisierten Form; im Standardisierungsprozess wurden zwar Änderungen erwogen, wegen der inzwischen schon fortgeschrittenen Verbreitung des WWW aber wieder verworfen


Im Sommer 1992 versuchte [[Tim Berners-Lee]] beim [[Internet Engineering Task Force|IETF-Meeting]] in Boston eine Arbeitsgruppe ins Leben zu rufen, die den Zugriff auf Dokumente im Web standardisieren sollte. Er schlug als Namen ''Universal Document Identifier (UDI)'' vor, womit nach seiner Vorstellung ein allgemeiner Internet-Standard definiert werden sollte. Der Name wurde aber als zu „arrogant“ kritisiert, was vor allem am Wort ''universal'' (engl. für ''allgemeingültig'', ''umfassend'') lag. Stattdessen wurde von der Gruppe der bescheidenere Begriff ''uniform'' (engl. für ''einheitlich'') vorgeschlagen. Außerdem wurde „Document“ durch „Resource“ ersetzt, um zu unterstreichen, dass das Web mit anderen Informationssystemen integriert werden sollte. Die URI-Arbeitsgruppe kam schließlich zustande, wobei noch eine weitere Namensänderung für den zu definierenden Standard beschlossen wurde: „Identifier“ wurde durch „Locator“ ersetzt, um zu betonen, dass es sich bei Web-Adressen nicht um dauerhaft registrierte Adressen handelt.<ref>Berners-Lee 1999, S. 62.</ref>
Im Sommer 1992 versuchte [[Tim Berners-Lee]] beim [[Internet Engineering Task Force|IETF-Meeting]] in Boston eine Arbeitsgruppe ins Leben zu rufen, die den Zugriff auf Dokumente im Web standardisieren sollte
* Er schlug als Namen ''Universal Document Identifier (UDI)'' vor, womit nach seiner Vorstellung ein allgemeiner Internet-Standard definiert werden sollte
* Der Name wurde aber als zu „arrogant“ kritisiert, was vor allem am Wort ''universal'' (engl. für ''allgemeingültig'', ''umfassend'') lag
* Stattdessen wurde von der Gruppe der bescheidenere Begriff ''uniform'' (engl. für ''einheitlich'') vorgeschlagen
* Außerdem wurde „Document“ durch „Resource“ ersetzt, um zu unterstreichen, dass das Web mit anderen Informationssystemen integriert werden sollte
* Die URI-Arbeitsgruppe kam schließlich zustande, wobei noch eine weitere Namensänderung für den zu definierenden Standard beschlossen wurde: „Identifier“ wurde durch „Locator“ ersetzt, um zu betonen, dass es sich bei Web-Adressen nicht um dauerhaft registrierte Adressen handelt


Aufgrund der konfliktreichen Arbeitsweise der Gruppe wurde der erste –&nbsp;noch informelle&nbsp;– Standardisierungsentwurf RFC 1630 erst im Juni 1994 von Berners-Lee vorgelegt.<ref name="Berners-Lee. 1999, S. 63" /> Er nennt den von Berners-Lee favorisierten Namen „Universal Resource Identifiers“ im Titel und definiert bereits die Begriffe URI, URL und [[Uniform Resource Name|URN]]. Im Dezember 1994 wurde von der Gruppe mit RFC 1738 der Standard mit dem Titel „Uniform Resource Locators (URL)“ veröffentlicht.
Aufgrund der konfliktreichen Arbeitsweise der Gruppe wurde der erste –&nbsp;noch informelle&nbsp;– Standardisierungsentwurf RFC 1630 erst im Juni 1994 von Berners-Lee vorgelegt. Er nennt den von Berners-Lee favorisierten Namen „Universal Resource Identifiers“ im Titel und definiert bereits die Begriffe URI, URL und [[Uniform Resource Name|URN]]
* Im Dezember 1994 wurde von der Gruppe mit RFC 1738 der Standard mit dem Titel „Uniform Resource Locators (URL)“ veröffentlicht


=== Bestandteile ===
=== Bestandteile ===
Berners-Lee entlehnte die einzelnen Bestandteile zum Teil bewusst von bereits existierenden Systemen, um Webadressen neuen Anwendern möglichst unmittelbar vertraut respektive logisch erscheinen zu lassen:<ref name="tbl_faq">{{Internetquelle |autor=Tim Berners-Lee |url=http://www.w3.org/People/Berners-Lee/FAQ.html#etc |titel=Frequently asked questions – Why the //, #, etc? |datum=2007-11-20 |abruf=2010-12-22}}</ref>
Berners-Lee entlehnte die einzelnen Bestandteile zum Teil bewusst von bereits existierenden Systemen, um Webadressen neuen Anwendern möglichst unmittelbar vertraut respektive logisch erscheinen zu lassen:
* Der Pfad (<code><nowiki>http://www.example.com</nowiki>'''/verzeichnis/unterverzeichnis/datei.html'''</code>) zitiert direkt die Pfad-Syntax in [[Dateisystem#Hierarchische Dateisysteme|UNIX-Dateisystemen]].<ref name="tbl_faq" />
* Der Pfad (<code><nowiki>http://www.example.com</nowiki>'''/verzeichnis/unterverzeichnis/datei.html'''</code>) zitiert direkt die Pfad-Syntax in [[Dateisystem#Hierarchische Dateisysteme|UNIX-Dateisystemen]]
* Die mit einem Doppel-Schrägstrich eingeleitete Notation des Hosts stammt aus der Syntax des [[Dateisystem#Netzwerkdateisysteme|Netzwerk-Dateisystems]] von [[Apollo Computer|Apollo Domain/OS]], in der Pfade auf entfernten Hosts nach dem Muster <code>'''//example.com'''/verzeichnis/unterverzeichnis/…</code> adressiert wurden.<ref name="tbl_faq" />
* Die mit einem Doppel-Schrägstrich eingeleitete Notation des Hosts stammt aus der Syntax des [[Dateisystem#Netzwerkdateisysteme|Netzwerk-Dateisystems]] von [[Apollo Computer|Apollo Domain/OS]], in der Pfade auf entfernten Hosts nach dem Muster <code>'''//example.com'''/verzeichnis/unterverzeichnis/…</code> adressiert wurden
* Das mit einem [[Doppelkreuz (Schriftzeichen)|Doppelkreuz]] markierte Fragment ist der in den [[Vereinigte Staaten|USA]] üblichen Schreibweise für [[Apartment]]- und [[Suite (Zimmerflucht)|Suitenummern]] in Postadressen entlehnt: ''12&nbsp;Foo&nbsp;Avenue&nbsp;#34'' steht für ''Foo Avenue Nr.&nbsp;12, Apartment 34''. Entsprechend bedeutet <code>datei.html'''#ressource'''</code> ''Teil (Abschnitt, Kapitel&nbsp;…) <code>ressource</code>'' innerhalb des Dokuments <code>datei.html</code>.<ref name="tbl_faq" />
* Das mit einem [[Doppelkreuz (Schriftzeichen)|Doppelkreuz]] markierte Fragment ist der in den [[Vereinigte Staaten|USA]] üblichen Schreibweise für [[Apartment]]- und [[Suite (Zimmerflucht)|Suitenummern]] in Postadressen entlehnt: ''12&nbsp;Foo&nbsp;Avenue&nbsp;#34'' steht für ''Foo Avenue Nr.&nbsp;12, Apartment 34''
* Entsprechend bedeutet <code>datei.html'''#ressource'''</code> ''Teil (Abschnitt, Kapitel&nbsp;…) <code>ressource</code>'' innerhalb des Dokuments <code>datei.html</code>.<


== Siehe auch ==
<noinclude>
== Anhang ==
=== Siehe auch ===
{{Special:PrefixIndex/{{BASEPAGENAME}}}}
----
* [[Digital Object Identifier]]
* [[Digital Object Identifier]]
* [[Homographischer Angriff]]
* [[Homographischer Angriff]]
Zeile 249: Zeile 226:
* [[URL-Encoding|URL-Kodierung]] (Prozentzeichen-Kodierung)
* [[URL-Encoding|URL-Kodierung]] (Prozentzeichen-Kodierung)
* [[URL-Template]]
* [[URL-Template]]
{{Wiktionary|URL}}
== Literatur ==
* {{Literatur
  |Autor=[[Tim Berners-Lee]], Mark Fischetti
  |Titel=Der Web-Report. Der Schöpfer des World Wide Webs über das grenzenlose Potential des Internets
  |Verlag=Econ
  |Ort=München
  |Datum=1999
  |ISBN=3-430-11468-3
  |Originaltitel=Weaving the Web: The Original Design and Ultimate Destiny of the World Wide Web
  |Originalsprache=en}}


== Weblinks ==
=== RFC ===
* {{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Datum=2005-01 |Updated=6874 |Obsoletes=2732 |Errata=1}}
* {{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Datum=2005-01 |Updated=6874 |Obsoletes=2732 |Errata=1}}
* {{RFC-Internet |Autor=T. Berners-Lee, L. Masinter, M. McCahill |RFC=1738 |Titel=Uniform Resource Locators (URL) |Datum=1994-12 |Updated=1808 |Errata=1}}
* {{RFC-Internet |Autor=T. Berners-Lee, L. Masinter, M. McCahill |RFC=1738 |Titel=Uniform Resource Locators (URL) |Datum=1994-12 |Updated=1808 |Errata=1}}
* {{RFC-Internet |Autor=R. Fielding |RFC=1808 |Titel=Relative Uniform Resource Locators |Datum=1995-06 |Kommentar=Wurde durch RFC 3986 obsolete}}
* {{RFC-Internet |Autor=R. Fielding |RFC=1808 |Titel=Relative Uniform Resource Locators |Datum=1995-06 |Kommentar=Wurde durch RFC 3986 obsolete}}


== Einzelnachweise ==
; RFC
<references>
{| class="wikitable sortable options"
<ref name="mailto_scheme">{{RFC-Internet |RFC=6068 |Titel=The ‘mailto’ URI Scheme}}</ref>
|-
<ref name="file_scheme">{{RFC-Internet |RFC=8089 |Titel=The "file" URI Scheme}}</ref>
! Nummer !! Beschreibung
<ref name="rfc3986_3_1">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.1 |Abschnittstitel=Scheme}}</ref>
|-
<ref name="rfc3986_3_2_1">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.2.1 |Abschnittstitel=User Information}}</ref>
| 3986 || Uniform Resource Identifier (URI): Generic Syntax
<ref name="rfc3986_3_2_2">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.2.2 |Abschnittstitel=Host}}</ref>
|-
<ref name="rfc3986_3_2_3">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.2.3 |Abschnittstitel=Port}}</ref>
| 6874 || Representing IPv6 Zone Identifiers in Address Literals and Uniform Resource Identifiers
<ref name="rfc3986_3_3">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.4 |Abschnittstitel=Path}}</ref>
|-
<ref name="rfc3986_3_4">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.4 |Abschnittstitel=Query}}</ref>
| 8820 || URI Design and Ownership
<ref name="rfc3986_3_5">{{RFC-Internet |RFC=3986 |Titel=Uniform Resource Identifier (URI): Generic Syntax |Abschnitt=3.5 |Abschnittstitel=Fragment}}</ref>
|-
<ref name="SO-URL-Encoding">
| 4248 || The telnet URI Scheme
{{Internetquelle
|-
|autor=Matas Vaitkevicius
| 4266 || The gopher URI Scheme
|url=http://stackoverflow.com/a/29948396/1744774
|-
|titel=URL encoding the space character: + or %20?
| 6068 || The ‘mailto’ URI Scheme
|werk=stackoverflow.com
|-
|datum=2015-04-29
| 6196 || Moving mailserver: URI Scheme to Historic
|abruf=2016-04-08}}
|-
</ref>
| 6270 || The ‘tn3270’ URI Scheme
<ref name="W3-School">
|-
{{Internetquelle
| 8089 || The "file" URI Scheme
|url=http://www.w3schools.com/tags/ref_urlencode.asp
|}
|titel=HTML URL Encoding Reference
|werk=w3schools.com
|abruf=2016-04-08}}
</ref>
</references>


{{Normdaten|TYP=s|GND=4753514-3}}
=== Links ===
===== Weblinks =====


[[Kategorie:Semantisches Web]]
[[Kategorie:URI]]
[[Kategorie:URI]]
</noinclude>
</noinclude>

Aktuelle Version vom 4. Februar 2024, 14:16 Uhr

Uniform Resource Locator - URL

Beschreibung

Ein Uniform Resource Locator (Abk. URL; für einheitlicher Ressourcenzeiger) identifiziert und lokalisiert eine Ressource, beispielsweise eine Webseite, über die zu verwendende Zugriffsmethode (zum Beispiel das verwendete Netzwerkprotokoll wie HTTP oder FTP) und den Ort (engl. location) der Ressource in Computernetzwerken

  • Der ursprüngliche Standard wurde im Dezember 1994 als RFC 1738 publiziert, er ist inzwischen durch die Veröffentlichung mehrerer anderer RFCs obsolet

URLs sind eine Unterart der generellen Identifikationsbezeichnung mittels Uniform Resource Identifiern (URIs)

  • Da URLs die erste und häufigste Art von URIs darstellen, werden die Begriffe häufig synonym verwendet
  • Im allgemeinen Sprachgebrauch werden URLs auch als Internetadresse oder Webadresse bezeichnet, folgend) meist speziell URLs von Webseiten gemeint sind

Aufbau

Der grundsätzliche URL-Aufbau besteht aus einer die Zugriffsmethode festlegenden Schema-Bezeichnung (englisch scheme) und einem Schema-spezifischen Teil (scheme-specific part), die durch einen Doppelpunkt getrennt sind:

<scheme>:<scheme-specific-part>

Schema

Schema (scheme)

Legt fest, mit welcher technischen Methode die Ressource angesprochen werden soll. Ist meistens, aber nicht zwingend gleichlautend mit dem verwendeten Netzwerkprotokoll, über das die Ressource lokalisiert werden kann

  • Beispiele sind:
  • mit gleich lautendem Protokoll: http, https oder ftp
  • mit anderem Protokoll: mailto zum Schreiben einer E-Mail) oder file (zum Zugriff auf lokale Dateien)

Schema-spezifischer Teil

Schema-spezifischer Teil (scheme-specific part)

Je nach Schema sind unterschiedliche spezifische Angaben erforderlich und möglich

  • In den meisten Fällen beginnt er mit der Zeichenkette //, jedoch ist bei manchen Varianten auch lediglich der Doppelpunkt definiert
  • Die folgenden Beispiele beziehen sich auf das Hypertext Transfer Protocol (HTTP)

Benutzer/Kennwort

Benutzer und Kennwort (user, password)

Falls benötigt, können Login-Informationen aus Benutzername (user) und Kennwort (password) mit übermittelt werden. Diese werden, voneinander durch Doppelpunkt getrennt, dem Host mit einem trennenden At-Zeichen (@) vorangestellt

Auch wenn für dieses Beispiel das Protokoll HTTP gewählt wurde, ist die Angabe von Benutzername und Kennwort als Teil des URLs nicht Teil der HTTP-Spezifikation! Aktuelle Browser akzeptieren diese URL-Syntax zwar, fragen aber beim Benutzer nach, ob er sich wirklich mit den angegebenen Daten anmelden möchte

  • Der Internet Explorer 6 (ab Windows XP SP2) und neuere Versionen fallen hier aus dem Rahmen, indem sie diese URL-Syntax rundweg als fehlerhaft ablehnen
  • Mit einem Registry-Eintrag kann man sie zum gleichen Verhalten zwingen, wie es die Vorgänger bis Version 5.5 zeigen: Diese übernehmen die Anmeldedaten ungefragt und übergeben sie direkt an den Server

Bei einigen anderen Protokollen, etwa FTP, ist die Angabe der Benutzerdaten in der gezeigten Form dagegen völlig korrekt und durch die Standards abgedeckt

Host

Die Host-Komponente wird in Form einer IPv4-Adresse in dezimaler Schreibweise durch Punkte getrennt, in Form einer IPv6-Adresse in hexadezimaler Schreibweise durch Doppelpunkte getrennt und in eckige Klammern gesetzt oder in Form eines FQDN notiert

Port

Die Angabe des Ports erlaubt die Ansteuerung eines TCP-Ports

  • Wird kein Port angegeben, so wird der Standard-Port des jeweiligen Protokolls verwendet – zum Beispiel bei HTTP 80, bei HTTPS 443 und bei FTP 21

Pfad

Schema (scheme)

Der Pfad beschreibt eine bestimmte Ressource (diese kann sich beispielsweise mit der Verzeichnisstruktur des Zielsystems decken, also etwa eine Datei oder ein Verzeichnis) auf dem Server. Der Pfad kann auch leer sein

  • Ein leerer Pfad kann optional durch einen Slash ersetzt werden und ist zu diesem gleichbedeutend

Die Interpretation (Datei oder Verzeichnis; Textdatei liefern oder Skript ausführen) bleibt dem Server überlassen

  • Ein typisches Beispiel für die Interpretationsfreiheit ist das Verhalten bei der Anforderung des Pfades / durch einen Client: Je nach Einstellung liefert der Server etwa den Inhalt einer namentlich ausgezeichneten Datei (wie /index.html, /README, /HEADER), ohne dass dies für den anfragenden Client ersichtlich ist
  • Genauso kann der Server allerdings – je nach Protokoll – auch explizit zu dieser Ressource weiterleiten oder eine Verzeichnisauflistung ausgeben

Abfrage

Abfrage (Query)

Query-String Im Fall des HTTP kann nach dem eigentlichen Ressourcenzeiger – getrennt durch ein Fragezeichen – ein Query-String folgen. Damit können zusätzliche Informationen übertragen werden, die server- oder clientseitig weiterverarbeitet werden können

Fragment

Fragmentbezeichner Nach einem Doppelkreuz kann ein Teil der Ressource referenziert werden, typischerweise ein Anker in einer HTML-Seite, zu dem nach dem Aufrufen der Seite automatisch hinuntergescrollt wird: Der URL http://example.com/dokument.html#absatz3 würde, in dem hier fiktiven Dokument, den Browser dazu veranlassen, zum Anfang des dritten Absatzes zu scrollen

Beispiele

Für http(s)
 |-------------------- Schema-spezifischer Teil ----------------------|
 | |
https://maxmuster:geheim@www.example.com:8080/index.html?p1=A&p2=B#ressource
\___/ \_______/ \____/ \_____________/ \__/\_________/ \_______/ \_______/
 | | | | | | | |
Schema¹ Benutzer Kennwort Host Port Pfad Query Fragment

¹ hier gleich Netzwerkprotokoll

Für mailto
mailto:max@example.org
\____/ \_____________/
 | |
Schema² |
 E-Mail-Adresse gemäß RFC 5322

² hier kein Netzwerkprotokoll

Für news (in diesem Beispiel ist weder ein Netzwerkprotokoll noch eine Host-Adresse enthalten)
 news:alt.hypertext
 \__/ \___________/
 | |
Schema |
 Name der Newsgroup
Für file
 file:///verzeichnis/unterverzeichnis/datei
 \__/ \_________________________________/
 | |
Schema |
 Pfad zu einer lokalen Datei im Dateisystem des Rechners, der den URL interpretiert

Streng genommen hat das file-Schema die Form file://<host>/<path>, wobei aber der Host-Teil praktisch nicht verwendet wird, da das file-Schema mangels einer Möglichkeit, ein Netzwerkprotokoll für den Zugriff auf die Datei anzugeben, kaum sinnvoll über ein Netzwerk benutzt werden kann File-URLs werden beispielsweise in der Programmiersprache Java verwendet, um auf diese Weise auf lokale Dateien zuzugreifen. Je nach Browser ist oftmals das Öffnen von file-Links nur nach spezieller clientseitiger Konfiguration oder unter Zuhilfenahme von AddOns etc. möglich

Konkrete Beispiele
  • ftp://max:muster@ftp.example.comFTP mit Benutzer und Kennwort
  • http://de.wikipedia.orgWebsite ohne Pfad (Aufruf der Startseite)
  • http://de.wikipedia.org/wiki/Uniform_Resource_Locator … Website mit Pfad
  • https://de.wikipedia.org … wie Aufruf der Website ohne Pfadangabe, allerdings mit dem verschlüsselten Hypertext Transfer Protocol Secure
  • mailto:hans@example.org … zum Schreiben einer E-Mail an die angegebene Mailadresse (öffnet den Standard-Mailclient mit einer neuen, leeren Nachricht, in der die TO-Adresse vorausgefüllt ist)
  • news:alt.hypertext … Anzeige einer Usenet-Newsgruppe (generisch, ohne Angabe des Netzwerkprotokolls NNTP)
  • nntp:alt.hypertext … Anzeige einer Usenet-Newsgruppe (mit Angabe des Netzwerkprotokolls NNTP)
  • telnet:example.org … Start einer Telnet-Session
  • file:///foo/bar.txt … Zugriff auf eine lokale Datei

Relative URLs

Neben den bisher dargestellten absoluten oder vollständigen URLs gibt es auch relative URLs. Sie sind nur innerhalb eines Kontextes gültig, von dem sie Eigenschaften erben

  • Ihnen fehlt die Ortsangabe im World Wide Web oder einem echten Intranet
  • Sie sind vor allem in der Gruppe http, https und ftp möglich, aber auch bei mailto
  • Das entspräche einer Telefonnummer ohne Vorwahl (des Landes, des Ortsnetzes)
Relative URLs für http, https, ftp
Beginn Bedeutung Anmerkung Beispiel
// Selbes Protokoll sinnvoll, um http: oder https: der momentanen Umgebung zu verwenden //example.com/pfad/zu/datei
/ Selbe Domäne (host:port), „Wurzelverzeichnis /pfad/zu/datei
# Selbe Ressource Wirkung über Nebenwirkung #
#fragment Selbe Ressource, Sprungmarke #knoten
nichts Selbe Ressource
../ ein Pfad-Segment aufwärts Ein Server muss keine durch / gegliederte Pfad-Segmentierung unterstützen /pfad/zur/../zur/datei
./relativer/pfad
./
sonstige
Selbes Pfad-Segment

Relative URLs werden oft eingesetzt, um eine Gruppe zusammengehörender Ressourcen wahlweise in einem lokalen Dateisystem oder an unterschiedlichen Orten in verschiedenen Netzwerk-Domänen unverändert abzulegen und aufeinander zu verlinken

  • Im Übrigen ist die Interpretation des Identifikators (Zeichenkette zwischen host:port und #) jedem Server freigestellt – zwar handhabt es die weitaus überwiegende Anzahl der Server und jede Standard-Software wie oben angegeben, jedoch können / genau wie ? % & nach eigenen Regeln ausgewertet werden

Bei mailto: wäre eine relative URL mailto:Nachbar (ohne @) – sie gilt nur im lokalen Netzwerk

Zeichensatz

Reservierte Zeichen Sonderzeichen / ? # [ ] @ : & ' ( ) * + , ; =
Nicht reservierte Zeichen Buchstaben A–Z, a–z
Ziffern 0–9
Sonderzeichen - . _ ~
Leerzeichen

In bestimmten Fällen ist außerdem das Leerzeichen (dieses alternativ auch mit + oder %) in Prozentkodierung (%20) darzustellen

URLs in Texten

Anhang C von RFC 3986 empfiehlt, URIs (und damit auch URLs) in Texten

  • eigenständig auf einer Zeile
  • mit doppelten Anführungsstrichen "http://example.com/" oder
  • mit spitzen Klammern <http://example.com/>

gegen den Kontext und vor allem gegen die Interpunktion des Satzes abzugrenzen

URLs und Suchmaschinen

Da URLs komplex aufgebaut sein können, können schlecht gestaltete URLs die Auffindbarkeit von Inhalten durch Suchmaschinen behindern

  • Aus diesem Grund empfiehlt der Suchmaschinenbetreiber Google z. B. 
  • den bedachten Einsatz von Parametern in URLs. Google hat auch die Begrifflichkeit der kanonischen URL eingeführt
  • Eine kanonische URL ist demnach die URL der Seite, von der Google annimmt, dass sie die repräsentativste von mehrfachen Verweisen auf einer Website ist
  • Aus Sicht einer Suchmaschine sind z. B. 
  • die URL-Varianten "http://www.example.com/" , "http://example.com/" , "https://www.example.com/" und "https://example.com/"vier eigenständige Versionen, die – wenn keine kanonische URL definiert ist – zu "Duplicate-Content" und damit einer suboptimalen Sichtbarkeit führen können

Die Prüfung der URL-Struktur wird oft im Rahmen der sogenannten Suchmaschinenoptimierung durchgeführt

Geschichte

Name und Standardisierung

In der Anfangszeit des WWW (ab Ende 1990) fand sich in der Dokumentation auf info.cern.ch zunächst keine dedizierte Bezeichnung für die Adressierung von Webseiten, das Thema wurde nur beschreibend als „W3 document address“, „W3 name“, „W3 address“ oder „Hypertext Name“ dokumentiert Die damals spezifizierte (und in den ersten Webseiten verwendete) Gestalt der Adressierung entspricht aber schon der später als „URL“ standardisierten Form; im Standardisierungsprozess wurden zwar Änderungen erwogen, wegen der inzwischen schon fortgeschrittenen Verbreitung des WWW aber wieder verworfen

Im Sommer 1992 versuchte Tim Berners-Lee beim IETF-Meeting in Boston eine Arbeitsgruppe ins Leben zu rufen, die den Zugriff auf Dokumente im Web standardisieren sollte

  • Er schlug als Namen Universal Document Identifier (UDI) vor, womit nach seiner Vorstellung ein allgemeiner Internet-Standard definiert werden sollte
  • Der Name wurde aber als zu „arrogant“ kritisiert, was vor allem am Wort universal (engl. für allgemeingültig, umfassend) lag
  • Stattdessen wurde von der Gruppe der bescheidenere Begriff uniform (engl. für einheitlich) vorgeschlagen
  • Außerdem wurde „Document“ durch „Resource“ ersetzt, um zu unterstreichen, dass das Web mit anderen Informationssystemen integriert werden sollte
  • Die URI-Arbeitsgruppe kam schließlich zustande, wobei noch eine weitere Namensänderung für den zu definierenden Standard beschlossen wurde: „Identifier“ wurde durch „Locator“ ersetzt, um zu betonen, dass es sich bei Web-Adressen nicht um dauerhaft registrierte Adressen handelt

Aufgrund der konfliktreichen Arbeitsweise der Gruppe wurde der erste – noch informelle – Standardisierungsentwurf RFC 1630 erst im Juni 1994 von Berners-Lee vorgelegt. Er nennt den von Berners-Lee favorisierten Namen „Universal Resource Identifiers“ im Titel und definiert bereits die Begriffe URI, URL und URN

  • Im Dezember 1994 wurde von der Gruppe mit RFC 1738 der Standard mit dem Titel „Uniform Resource Locators (URL)“ veröffentlicht

Bestandteile

Berners-Lee entlehnte die einzelnen Bestandteile zum Teil bewusst von bereits existierenden Systemen, um Webadressen neuen Anwendern möglichst unmittelbar vertraut respektive logisch erscheinen zu lassen:

  • Der Pfad (http://www.example.com/verzeichnis/unterverzeichnis/datei.html) zitiert direkt die Pfad-Syntax in UNIX-Dateisystemen
  • Die mit einem Doppel-Schrägstrich eingeleitete Notation des Hosts stammt aus der Syntax des Netzwerk-Dateisystems von Apollo Domain/OS, in der Pfade auf entfernten Hosts nach dem Muster //example.com/verzeichnis/unterverzeichnis/… adressiert wurden
  • Das mit einem Doppelkreuz markierte Fragment ist der in den USA üblichen Schreibweise für Apartment- und Suitenummern in Postadressen entlehnt: 12 Foo Avenue #34 steht für Foo Avenue Nr. 12, Apartment 34
  • Entsprechend bedeutet datei.html#ressource Teil (Abschnitt, Kapitel …) ressource innerhalb des Dokuments datei.html.<


Anhang

Siehe auch


RFC

RFC
Nummer Beschreibung
3986 Uniform Resource Identifier (URI): Generic Syntax
6874 Representing IPv6 Zone Identifiers in Address Literals and Uniform Resource Identifiers
8820 URI Design and Ownership
4248 The telnet URI Scheme
4266 The gopher URI Scheme
6068 The ‘mailto’ URI Scheme
6196 Moving mailserver: URI Scheme to Historic
6270 The ‘tn3270’ URI Scheme
8089 The "file" URI Scheme

Links

Weblinks