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.
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 atabby
.
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
oorg
(ovvero un eTLD che corrisponde a un TLD), il dominio e il dominio di secondo livello che lo precede, ad esempioexample.com
oexample.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
egithub.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
oexample.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.
Cerca
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
emood=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 livellocom
.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 diau
eexample.org.au
è un sottodominio diorg.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'URLhttps://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
osa.edu.au
, il "sito" è costituito daischeme
, dall'eTLD e dall'etichetta che precede. Ad esempio, per l'URLhttps://cat.example.co.uk/tabby
il sito èhttps://example.co.uk
e perhttps://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 diexample.com
.support.api.example.org
è un sottodominio diapi.example.org
, che è un sottodominio diexample.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 diexample.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
eorg
è un dominio di secondo livello (anche seorg
è 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ù
- WhatWG: URL Living Standard
- WhatWG: HTML Living Standard
- API URL
- Informazioni su "stesso sito" e "stessa origine"
- RFC: Uniform Resource Locator (URL)
- RFC: URI, URL e URN
- Database della zona radice (directory dei TLD)
- Elenco di suffissi pubblici (directory di eTLDs): "un suffisso pubblico è un insieme di nomi DNS o caratteri jolly concatenati da punti. Rappresenta la parte di un nome di dominio che non è sotto il controllo del singolo registrante.")
- Glossario di ICANN
- Che cos'è un nome di dominio completo?
- In quanti modi puoi suddividere un URL e assegnare un nome alle parti?
- Glossario di MDN Web Docs
- Che cos'è un URL?
- La cronologia dell'URL