Quali sono le parti di un URL?

La maggior parte delle volte va bene dire frasi del tipo "Ho acquistato un dominio" o "Le nostre immagini sono ospitate su un sito diverso", anche se non è del tutto vero. Tuttavia, in alcuni contesti è necessario essere più precisi. Ad esempio, quando gestisci i cookie, devi capire la differenza tra site e origin.

I nomi delle parti dell'URL sono specificati in uno standard, che definisce anche un'API JavaScript:

  • Lo standard URL definisce gli URL e i concetti correlati per consentire agli ingegneri di creare browser web interoperabili.
  • Il componente API URL dello standard definisce i metodi per fornire l'accesso a parti di una stringa URL, come schema o origin.

Questo documento illustra una serie di termini utilizzati con le stringhe URL HTTP o HTTPS. Non tratta altri tipi di URL, come URL di file o dati. Per termini come host e origin, le definizioni accurate sono intrinsecamente complesse, perciò questo documento fornisce esempi e link allo standard degli URL, anziché tentare spiegazioni complete.

Puoi utilizzare JavaScript per ottenere i nomi dei componenti dell'URL definiti dall'API URL. Ad esempio:

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

Strumento di analisi URL

Modifica l'URL di seguito per vedere come vengono denominati le parti della stringa URL. Puoi anche aprire questo link in una scheda separata all'indirizzo url-parts.glitch.me.


I nomi delle parti dell'URL sono elencati di seguito in ordine alfabetico.

Dominio di primo livello nazionale (ccTLD)

Un dominio di primo livello definito nell'elenco dei codici paese ISO 3166-1.

  • Per https://example.org.au, il ccTLD è au.
  • Per https://example.io, il ccTLD è io.

Nome di dominio

Le parti di un URL HTTP o HTTPS separate da punti: tutto ciò che segue lo schema, ma prima del percorso o della porta (se specificato). Ogni parte del nome di dominio è nota come etichetta.

URL Nome di dominio
https://example.github.io/path example.github.io
https://support.example.org.au:443 support.example.org.au

Dominio di primo livello effettivo (eTLD)

Una voce nell'elenco dei suffissi pubblici, che include un TLD e(per i domini eTLD con più parti) domini aggiuntivi di seguito: secondo livello, terzo livello e così via.

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

Un "suffisso pubblico", come questi esempi, è un nome con cui è possibile registrare i domini. L'elenco dei suffissi pubblici è un elenco di tutti i suffissi pubblici noti e viene aggiornato di frequente. Alcuni browser, tra cui Chromium e Firefox, utilizzano l'elenco nelle build.

eTLD+1

Vedi dominio registrabile.

Un eTLD più il sottodominio che lo precede.

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

Nome file

Non definita nello standard dell'URL e non parte dell'API dell'URL, ma comunemente utilizzata per fare riferimento alla parte finale, non di percorso, dell'URL basata sul presupposto, spesso errato, che l'URL sia mappato direttamente a una struttura di directory.

Ad esempio, con https://example.com/dir/file.html, file.html potrebbe essere definito il nome file.

Il nome file viene utilizzato anche dai browser per assegnare un nome a un asset quando viene scaricato. Ad esempio, https://example.com/images/image.jpg in genere viene salvato localmente in image.jpg.

Fragment

Una stringa che segue un carattere # alla fine di un URL che fornisce un identificatore di frammento.

  • Ad esempio: l'URL https://example.com/cats#tabby ha un valore per l'identificatore del frammento pari a tabby.

La parte che include # è nota come hash o anchor. Puoi anche inserire un link a un frammento di testo ed evidenziarlo.

L'hash viene restituito dall'API URL anziché dal frammento.

Nome di dominio completo (FQDN)

L'indirizzo completo di un sito web o server, mappato a un indirizzo IP.

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

Il nome di dominio completo di un URL non include la porta, anche se viene utilizzata una porta non predefinita.

Hash (o anchor)

Una stringa che segue un carattere # alla fine di un URL che fornisce un identificatore di frammento. In alcuni contesti questo viene chiamato "ancoraggio".

La parte che esclude # è nota come frammento. Puoi anche inserire un link a un frammento di testo ed evidenziarlo.

L'hash viene restituito dall'API URL anziché dal frammento.

Host

Come definito nello standard URL, un host può essere un nome di dominio, un indirizzo IP v4, un indirizzo IPv6, un host opaco o un host vuoto.

  • La definizione di host dello standard URL non include la porta.
  • URL.host include la porta, a meno che questa non sia quella predefinita per lo schema.
  • URL.hostname non include la porta.
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

Nome host

Il nome host viene definito dall'API JavaScript URL, ma non altrove dallo standard dell'URL. Per ulteriori dettagli, consulta la sezione relativa alla rappresentazione host.

URL.hostname restituisce l'host senza la porta.

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

Origin

Lo standard URL definisce origin e collega allo standard HTML per lo sfondo.

Per gli URL HTTP o HTTPS, URL.origin restituisce lo schema, l'host e la porta (a meno che la porta non sia quella predefinita per lo 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

Parametro

Consulta i parametri di ricerca

Password

Vedi nome utente.

Nome percorso

Per un URL HTTP o HTTPS, la parte dopo il dominio e la porta (se definiti), incluso un filename (se definito), ma senza includere la stringa di ricerca o l'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

"Percorso" a volte viene usato per fare riferimento al nome del percorso senza il nome file. Ad esempio, per l'URL https://example.com/cat/pattern/tabby.html, il "percorso" è /cat/pattern.

Porta

Il numero dopo : in un URL che identifica una porta di rete. Ad esempio, per l'URL https://example.com:1234/tabby il numero di porta è 1234.

Il numero di porta deve essere un numero intero senza segno a 16 bit, ovvero un numero intero compreso tra 0 e 65535 inclusi.

Per un URL HTTP, la porta predefinita è 80; per HTTPS, la porta predefinita è 443. Non è necessario che un URL specifichi il numero di porta, a meno che non venga utilizzata una porta non predefinita.

L'API restituisce una stringa vuota se la porta è quella predefinita per lo schema.

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

Protocollo

Lo schema seguito da : (ad esempio http: o https:).

protocol è disponibile dall'API URL, mentre scheme non lo è.

Query (o "stringa di query")

La parte dell'URL relativa alla ricerca, esclusi i ? iniziali.

Dominio registrabile

  • Per un URL con un eTLD composto da una singola parte come com o org (ovvero un eTLD che corrisponde a un TLD), il dominio e il dominio di secondo livello che lo precede, ad esempio example.com o example.org.
  • Per un URL con un eTLD in due parti in cui è consentita solo la registrazione di terzo livello (ovvero voci nell'elenco di suffissi pubblici come com.au e github.io), il dominio di primo livello in due parti ("suffisso pubblico") e il nome di dominio di terzo livello subito prima. Ad esempio: example.org.au o example.github.io.
  • Per i domini eTLD con tre o più parti, l'eTLD e il dominio precedente.

Scheme

La parte dell'URL (prima di ://) che definisce il protocollo di rete (o l'azione che deve essere eseguita dallo user agent) quando viene effettuata una richiesta a un URL. Ad esempio, una richiesta a un URL con uno schema https deve essere effettuata utilizzando il protocollo HTTPS. Per una richiesta a un URL con uno schema come file, mailto o git che non corrisponde a un protocollo di rete, il comportamento dipende dallo user agent. Ad esempio, quando un utente fa clic su un link mailto, la maggior parte dei browser apre l'applicazione email predefinita utilizzando i valori nell'URL href del link.

Un punto interrogativo seguito da una serie di coppie chiave-valore che rappresentano i parametri e i relativi valori, forniti dopo pathname.

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

Il valore query o "stringa di query" si riferisce all'elemento search senza il valore ? principale.

Vedi anche Parametri di ricerca.

Cerca parametri

Fai riferimento a un elemento di dati passati in una stringa di ricerca (o "stringa di query").

  • Ad esempio: per https://example.com/cats?pattern=tabby&mood=bonkers, la stringa di ricerca ha due parametri: pattern=tabby e mood=bonkers.

Dominio di secondo livello

Il dominio prima di un dominio di primo livello.

  • Per l'URL https://www.example.com, il dominio di secondo livello è example.com, un sottodominio del dominio di primo livello com.

  • Per https://example.org.au, il dominio di primo livello è au, il dominio di secondo livello è org e il dominio di terzo livello è example. In questo esempio, org.au è un sottodominio di au e example.org.au è un sottodominio di org.au.

Sito

Il parametro Sito è definito dallo standard HTML, insieme a same-site, che include lo schema e senza schema sullo stesso sito.

Il sito non è definito nello standard URL o nell'API JavaScript URL.

In questo contesto:

  • Per un URL HTTP o HTTPS con un eTLD composto da un'unica parte, ad esempio https://example.com, il sito è costituito dall'scheme, dall'eTLD e dall'etichetta che lo precede. Ad esempio, per l'URL https://www.example.com/cat, il sito è https://example.com. Per questo URL, l'eTLD è uguale al dominio di primo livello.
  • Per gli eTLD multiparte, come co.uk, github.io o sa.edu.au, il "sito" è costituito dai scheme, dall'eTLD e dall'etichetta che precede. Ad esempio, per l'URL https://cat.example.co.uk/tabby il sito è https://example.co.uk e per https://www.education.sa.gov.au il sito è https://education.sa.gov.au.
URL Sito (con schema e eTLD +1)
https://cat.example.com/tabby ("https", "example.com")
https://cat.example.co.uk/tabby ("https", "example.co.uk")

A differenza di origin, il sito non include port.

Sottodominio

Un dominio all'interno di un dominio di livello superiore.

Per i siti con domini di primo livello a una sola parte come com o org, le parti che precedono il dominio di primo livello, ciascuna separata da un punto.

  • www.example.com è un sottodominio di example.com.
  • support.api.example.org è un sottodominio di api.example.org, che è un sottodominio di example.org.

Per i domini eTLD in due parti in cui sono consentite solo registrazioni di terzo livello(ovvero voci nell'elenco dei suffissi pubblici come co.uk e github.io), i sottodomini sono le parti del nome di dominio che precedono.

  • Ad esempio: cat.example.co.uk è un sottodominio di example.co.uk.

Frammento di testo

Un tipo di frammento che consente di collegare ed evidenziare un intervallo di testo all'interno di una pagina. Quando un utente segue un link con un frammento di testo, il browser tenta di individuare, scorrere ed evidenziare il testo all'interno della pagina.

Un frammento di testo inizia con :~:text= seguito dal termine di ricerca.

Ad esempio, per creare un link alla prima occorrenza del testo "frammento" in questa pagina, utilizza l'URL https://web.dev/articles/url-parts#:~:text=fragment.

Scopri di più: frammenti di testo.

Dominio di primo livello (TLD)

Un nome di dominio elencato nel database della zona radice, ad esempio com o org. Alcuni domini di primo livello sono domini di primo livello con codice paese, come uk e tv.

Nel descrivere le parti di un URL HTTP o HTTPS, il dominio di primo livello è il nome di dominio che segue il punto finale.

  • Per https://example.org, il dominio di primo livello dell'URL è org.
  • Per https://example.org.au, il dominio di primo livello dell'URL è au e org è un dominio di secondo livello (anche se org è anche un dominio di primo livello). org.au è un eTLD in due parti.

L'elenco dei suffissi pubblici dei eTLD include domini con una, due o più parti, quindi un dominio di primo livello può essere anche un eTLD. Ad esempio:

  • Per https://example.com, l'eTLD dell'URL è com, che è anche un dominio di primo livello.

Nome utente

Puoi specificare nome utente e password facoltativi all'inizio dell'URL, ma sono stati ritirati per motivi di sicurezza e in molti casi verranno ignorati.

Ad esempio, con https://user123:password1@example.com il nome utente è user123. Tieni presente che il nome utente (e la password) sono in testo normale e non sono criptati. Se il nome utente contiene simboli : o @, la codifica URL deve essere rispettivamente %3A e %40.


Scopri di più