Aus welchen Teilen besteht eine URL?

Meistens ist es in Ordnung, Dinge wie „Ich habe eine Domain gekauft“ oder „Unsere Bilder werden auf einer anderen Website gehostet“ zu sagen, auch wenn dies nicht ganz der Wahrheit entspricht. In einigen Kontexten ist es jedoch erforderlich, genauer zu sein. Wenn Sie beispielsweise mit Cookies arbeiten, müssen Sie den Unterschied zwischen Website und Herkunft kennen.

Die Namen der URL-Teile werden in einem Standard angegeben, der auch eine JavaScript API definiert:

  • Der URL-Standard definiert URLs und zugehörige Konzepte, damit Entwickler interoperable Webbrowser erstellen können.
  • Die Komponente URL API des Standards definiert Methoden, um Zugriff auf Teile eines URL-Strings zu gewähren, z. B. auf das Schema oder den Ursprung.

In diesem Dokument werden verschiedene Begriffe erläutert, die in HTTP- oder HTTPS-URL-Strings verwendet werden. Andere URL-Typen wie Datei- oder Daten-URLs werden nicht behandelt. Genaue Definitionen für Begriffe wie host und origin sind von Natur aus komplex. Daher enthält dieses Dokument Beispiele und Links zum URL-Standard, anstatt vollständige Erklärungen zu liefern.

Mit JavaScript können Sie die Namen von URL-Komponenten abrufen, die durch die URL API definiert werden. Beispiel:

let url = new URL('https://foo.com.au:1234/bar/foo.html#bar');
console.log(url);

URL-Analyse-Tool

Bearbeiten Sie die folgende URL, um zu sehen, wie Teile des URL-Strings benannt sind. Sie können die Datei auch in einem separaten Tab unter url-parts.glitch.me öffnen.


Die Namen für URL-Teile sind unten alphabetisch aufgeführt.

Länderspezifische Top-Level-Domain (ccTLD)

Eine Top-Level-Domain, die in der Liste der Ländercodes nach ISO 3166-1 definiert ist.

  • Für https://example.org.au lautet die ccTLD au.
  • Für https://example.io lautet die ccTLD io.

Domainname

Die Teile einer HTTP- oder HTTPS-URL, die durch Punkte getrennt sind: alles nach dem Schema, aber vor dem Pfad oder Port (falls angegeben). Jeder Teil des Domainnamens wird als Label bezeichnet.

URL Domainname
https://example.github.io/path example.github.io
https://support.example.org.au:443 support.example.org.au

Effektive Top-Level-Domain (eTLD)

Ein Eintrag in der Liste öffentlicher Suffixe, einschließlich einer TLD und (bei eTLDs mit mehreren Teilen) zusätzlicher Domains darunter: zweite Ebene, dritte Ebene usw.

  • Beispiel: com, com.au, github.io, sa.edu.au, schools.nsw.edu.au.

Ein „öffentlicher Suffix“, wie in diesen Beispielen, ist ein Name, unter dem Domains registriert werden können. Die öffentliche Suffixliste enthält alle bekannten öffentlichen Suffixe und wird häufig aktualisiert. Browser wie Chromium und Firefox verwenden die Liste in ihren Builds.

eTLD+1

Siehe Registrable Domain.

Eine eTLD und die vorangehende Subdomain.

  • Beispiel: example.com, example.org.au, example.github.io, example.sa.edu.au, example.schools.nsw.edu.au.

Dateiname

Nicht im URL-Standard definiert und nicht Teil der URL API, wird aber in der Regel verwendet, um auf den finalen Teil der URL ohne Pfad zu verweisen, basierend auf der häufig falschen Annahme, dass die URL direkt einer Verzeichnisstruktur zugeordnet ist.

Bei https://example.com/dir/file.html könnte file.html beispielsweise als Dateiname bezeichnet werden.

Der Dateiname wird auch von Browsern verwendet, um ein Asset beim Herunterladen zu benennen. Beispielsweise wird https://example.com/images/image.jpg normalerweise lokal unter image.jpg gespeichert.

Fragment

Ein String nach dem Zeichen # am Ende einer URL, der eine Fragmentkennung enthält.

  • Beispiel: Die URL https://example.com/cats#tabby hat den Wert für die Fragment-ID tabby.

Der Teil mit der # wird als Hash oder Anker bezeichnet. Sie können auch einen Link zu einem Textfragment erstellen und es hervorheben.

Der Hash wird von der URL API und nicht vom Fragment zurückgegeben.

Voll qualifizierter Domainname (FQDN)

Eine vollständige Adresse einer Website oder eines Servers, die einer IP-Adresse zugeordnet ist.

URL FQDN
https://example.com:1234/cats example.com
https://api.example.github.io api.example.github.io

Der FQDN einer URL enthält keinen Port, auch wenn ein nicht standardmäßiger Port verwendet wird.

Hash (oder Anker)

Ein String, der auf ein #-Zeichen am Ende einer URL folgt und eine Fragment-ID bereitstellt. In einigen Kontexten wird dies als „Anker“ bezeichnet.

Der Teil ohne # wird als Fragment bezeichnet. Sie können auch einen Link zu einem Textfragment erstellen und es hervorheben.

Der Hash wird von der URL API und nicht vom Fragment zurückgegeben.

Host

Gemäß der Definition im URL-Standard kann ein Host ein Domainname, eine IPv4-Adresse, eine IPv6-Adresse, ein undurchsichtiger Host oder ein leerer Host sein.

  • Die Definition von host im URL-Standard enthält den port nicht.
  • URL.host enthält den Port, es sei denn, er ist der Standardport für das Schema.
  • URL.hostname enthält keinen Port.
URL URL.host
https://www.example.com:443/cat www.example.com
// 443 is the default port for the scheme
https://www.example.com:1234/cat www.example.com:1234
https://cat.example.github.io cat.example.github.io

Hostname

Der Hostname wird von der JavaScript URL API definiert, nicht jedoch vom URL-Standard. Weitere Informationen finden Sie unter Hostdarstellung.

URL.hostname gibt den Host ohne den Port zurück.

URL URL.hostname
https://www.example.com:443/cat www.example.com
https://www.example.com:1234/cat www.example.com
https://cat.example.github.io cat.example.github.io

Ursprung

Der URL-Standard definiert origin und verweist für den Hintergrund auf den HTML-Standard.

Bei HTTP- oder HTTPS-URLs gibt URL.origin das Schema, den Host und den Port zurück (es sei denn, der Port ist der Standardport für das Schema).

URL URL.origin
https://www.example.com:443/cat https://www.example.com
https://www.example.com:1234/cat https://www.example.com:1234
https://cat.example.github.io https://cat.example.github.io

Parameter

Weitere Informationen finden Sie unter Suchparameter.

Passwort

Siehe username.

Pfadname

Bei einer HTTP- oder HTTPS-URL der Teil nach der Domain und dem Port (falls definiert), einschließlich eines Dateinamens (falls definiert), aber ohne Suchstring oder Hash.

URL URL.pathname
https://example.com [empty string]
https://example.com:8000/search?q=tabby /search
https://example.github.io/cat/pattern#tabby /cat/pattern
https://example.github.io/README.md /README.md

„Pfad“ bezieht sich manchmal auf den Pfad ohne Dateinamen. Bei der URL https://example.com/cat/pattern/tabby.html ist „path“ beispielsweise /cat/pattern.

Port

Die Zahl nach einem : in einer URL, die einen Netzwerkport identifiziert. Beispiel: Für die URL https://example.com:1234/tabby lautet die Portnummer 1234.

Die Portnummer muss eine 16‑Bit-unsignierte Ganzzahl sein, also eine Ganzzahl zwischen 0 und 65.535.

Für eine HTTP-URL ist der Standardport 80 und für HTTPS 443. In einer URL muss die Portnummer nur angegeben werden, wenn ein nicht standardmäßiger Port verwendet wird.

Die API gibt einen leeren String zurück, wenn der Port der Standardport für das Schema ist.

URL URL.port
https://example.com // empty string
https://example.com:443/foo // empty string: port is default for scheme
https://www.example.com:1234/foo 1234

Protokoll

Das Schema gefolgt von : (z. B. http: oder https:).

protocol ist über die URL API verfügbar, scheme jedoch nicht.

Abfrage (oder „Abfragestring“)

Der Teil search der URL, ausgenommen das vorangestellte ?.

Registrierbare Domain

  • Bei einer URL mit einer einteiligen eTLD wie com oder org (d. h. einer eTLD, die einer TLD entspricht), die Domain und die davor stehende Second-Level-Domain: z. B. example.com oder example.org.
  • Bei einer URL mit einer zweiteiligen eTLD, bei der nur die Registrierung auf dritter Ebene zulässig ist (d. h. Einträge in der öffentlichen Suffixliste wie com.au und github.io), die zweiteilige Top-Level-Domain („öffentliches Suffix“) und der Domainname der dritten Ebene direkt davor. Beispiel: example.org.au oder example.github.io.
  • Bei eTLDs mit drei oder mehr Teilen die eTLD und die Domain davor.

Schema

Der Teil der URL (vor ://), der das Netzwerkprotokoll (oder die vom User-Agent auszuführende Aktion) definiert, wenn eine Anfrage an eine URL gesendet wird. Eine Anfrage an eine URL mit einem https-Schema sollte beispielsweise über das HTTPS-Protokoll erfolgen. Bei einer Anfrage an eine URL mit einem Schema wie file, mailto oder git, das keinem Netzwerkprotokoll entspricht, hängt das Verhalten vom User-Agent ab. Klickt ein Nutzer beispielsweise auf einen mailto-Link, öffnen die meisten Browser die Standard-E-Mail-Anwendung und verwenden dabei die Werte in der href-URL des Links.

Ein Fragezeichen gefolgt von einer Reihe von Schlüssel/Wert-Paaren, die Parameter und ihre Werte darstellen, die nach dem Pfadnamen angegeben werden.

URL URL.search
https://example.com/cats?pattern=tabby&mood=bonkers ?pattern=tabby&mood=bonkers
https://example.com/cats:443?pattern=tabby ?pattern=tabby

Der query oder „Abfragestring“ bezieht sich auf den search ohne das vorangestellte ?.

Siehe auch Suchparameter.

Suchparameter

Bezieht sich auf ein Datenelement, das in einem Suchstring (oder „Abfragestring“) übergeben wird.

  • Beispiel: Für https://example.com/cats?pattern=tabby&mood=bonkers enthält der Suchstring zwei Parameter: pattern=tabby und mood=bonkers.

Second-Level-Domain

Die Domain vor einer Top-Level-Domain.

  • Bei der URL https://www.example.com ist example.com die Second-Level-Domain, eine Subdomain der Top-Level-Domain com.

  • Bei https://example.org.au ist au die Top-Level-Domain, org die Second-Level-Domain und example die Third-Level-Domain. In diesem Beispiel ist org.au eine Subdomain von au und example.org.au eine Subdomain von org.au.

Website

Site ist durch den HTML-Standard definiert, zusammen mit same-site, d. h. mit Schema, und schemeless-same-site.

„Website“ ist im URL-Standard oder in der JavaScript URL API nicht definiert.

In diesem Zusammenhang:

  • Bei einer HTTP- oder HTTPS-URL mit einer einteiligen eTLD wie https://example.com besteht die Website aus der scheme, der eTLD und dem Label davor. Beispiel: Für die URL https://www.example.com/cat ist die Website https://example.com. Bei dieser URL entspricht die eTLD der Top-Level-Domain.
  • Bei mehrteiligen eTLD wie co.uk, github.io oder sa.edu.au besteht die „Website“ aus der scheme, der eTLD und dem Label davor. Beispiel: Für die URL https://cat.example.co.uk/tabby ist die Website https://example.co.uk und für https://www.education.sa.gov.au https://education.sa.gov.au.
URL Website (mit Schema und eTLD +1)
https://cat.example.com/tabby ("https", "beispiel.de")
https://cat.example.co.uk/tabby ("https", "beispiel.de")

Im Gegensatz zu origin enthält die Website keinen port.

Subdomain

Eine Domain innerhalb einer übergeordneten Domain.

Bei Websites mit einteiligen Top-Level-Domains wie com oder org die Teile vor der Top-Level-Domain, die jeweils durch einen Punkt getrennt sind.

  • www.example.com ist eine Subdomain von example.com.
  • support.api.example.org ist eine Subdomain von api.example.org, die wiederum eine Subdomain von example.org ist.

Bei zweiteiligen eTLDs, bei denen nur Registrierungen auf dritter Ebene zulässig sind (d. h. Einträge in der öffentlichen Suffixliste wie co.uk und github.io), sind die Subdomains die Teile des Domainnamens davor.

  • Beispiel: cat.example.co.uk ist eine Subdomain von example.co.uk.

Textfragment

Eine Art von Fragment, mit dem ein Textbereich auf einer Seite verlinkt und hervorgehoben werden kann. Wenn ein Nutzer einem Link mit einem Textfragment folgt, versucht der Browser, den Text auf der Seite zu finden, zu scrollen und hervorzuheben.

Ein Textfragment beginnt mit :~:text= gefolgt vom Suchbegriff.

Wenn Sie beispielsweise zum ersten Vorkommen des Texts „Fragment“ auf dieser Seite verlinken möchten, verwenden Sie die URL https://web.dev/articles/url-parts#:~:text=fragment.

Weitere Informationen zu Textfragmenten

Top-Level-Domain (TLD)

Ein Domainname, der in der Stammzonendatenbank aufgeführt ist, z. B. com oder org. Einige Top-Level-Domains sind Top-Level-Domains mit Ländercode, z. B. uk und tv.

Bei der Beschreibung der Teile einer HTTP- oder HTTPS-URL ist die TLD der Domainname, der auf den letzten Punkt folgt.

  • Bei https://example.org ist org die Top-Level-Domain der URL.
  • Bei https://example.org.au lautet die Top-Level-Domain der URL au und org eine Second-Level-Domain (auch wenn org auch eine Top-Level-Domain ist). org.au ist eine zweiteilige eTLD.

Die öffentliche Suffixliste der eTLD enthält Domains mit einem, zwei oder mehr Teilen. Eine TLD kann also auch eine eTLD sein. Beispiel:

  • Für https://example.com lautet die eTLD der URL com, die auch eine TLD ist.

Nutzername

Zu Beginn der URL können ein optionaler Nutzername und ein Passwort angegeben werden. Diese Option wurde jedoch aus Sicherheitsgründen eingestellt und wird in vielen Fällen ignoriert.

Bei https://user123:password1@example.com lautet der Nutzername beispielsweise user123. Der Nutzername (und das Passwort) sind im Klartext und nicht verschlüsselt. Wenn der Nutzername die Symbole : oder @ enthält, müssen sie URL-codiert zu %3A bzw. %40 werden.


Weitere Informationen