Passer au contenu principal

Comprendre la structure d'une URL 🔗

Vous voyez des URL tous les jours en utilisant Internet, mais vous ne savez peut-être pas ce que signifie chaque partie. Comprendre la structure d'une URL rend le développement web beaucoup plus facile ! Explorons cela étape par étape.

Comparer une URL à la vie quotidienne ?

Comparons une URL à une adresse postale.

L'histoire de l'adresse postale 📬

France, Paris, 75008, Avenue des Champs-Élysées 123, Bâtiment ABC, 5e étage, Bureau 501
↓ ↓ ↓ ↓ ↓ ↓ ↓
Pays Ville Code postal Rue Bâtiment Étage Bureau

Une URL est similaire :

https://www.example.com:443/products/shoes?color=red&size=10#reviews
↓ ↓ ↓ ↓ ↓ ↓
Protocole Domaine Port Chemin Chaîne de requête Hash

Définition d'une URL

URL (Uniform Resource Locator)

  • Adresse indiquant l'emplacement d'une ressource (page, image, fichier, etc.) sur Internet
  • Aussi appelé "adresse web" ou "lien"

Vue d'ensemble de la structure complète d'une URL

https://user:pass@www.example.com:443/products/shoes?color=red&size=10#reviews
└──┬─┘ └────┬────┘└───────┬───────┘└┬┘└──────┬──────┘└────────┬────────┘└──┬──┘
Protocole Auth. Domaine Port Chemin Chaîne de requête Hash/Fragment

Examinons chaque partie en détail !

1. Protocole (Protocol) 🔐

Comment se connecter au site web

https://example.com
└──┬─┘
Protocole

Principaux protocoles

HTTP (HyperText Transfer Protocol)

http://example.com
  • Méthode ordinaire de connexion au site web
  • Pas de sécurité ⚠️
  • Les données ne sont pas cryptées
  • Rarement utilisé de nos jours

HTTPS (HTTP Secure)

https://example.com
  • Méthode de connexion au site web sécurisée 🔒
  • Les données sont cryptées
  • Standard des sites web modernes
  • Affiche l'icône de cadenas 🔒

Autres protocoles

ftp://example.com      # Transfert de fichiers
mailto:user@email.com # Envoi d'e-mail
file:///C:/folder # Fichier local
Astuce

Utilisez toujours HTTPS ! Vérifiez toujours que c'est HTTPS, surtout lors de la connexion, du paiement et de la saisie d'informations personnelles.

2. Domaine (Domain) 🌐

Le nom du site web

https://www.example.com
└──────┬──────┘
Domaine

Structure du domaine

www.example.com
└┬┘ └──┬──┘└┬┘
Sous- Nom TLD
domaine (domaine de premier niveau)

Domaine de premier niveau (TLD - Top Level Domain)

.com  →  Commercial (le plus courant)
.net → Réseau
.org → Organisation/à but non lucratif
.edu → Établissement d'enseignement
.gov → Gouvernement
.io → IT/Startup (populaire)
.fr → France

Sous-domaine (Subdomain)

www.example.com      →  Site web
blog.example.com → Blog
api.example.com → Serveur API
admin.example.com → Page d'administration

Exemple réel

https://blog.example.fr
└┬┘ └──┬──┘└┬┘
Sous- Principal TLD
domaine domaine

3. Port (Port) 🚪

Par quelle porte du serveur entrer

https://example.com:443
└┬┘
Port

Port par défaut

Généralement omis (ajouté automatiquement) :

http://example.com       →  http://example.com:80 (automatique)
https://example.com → https://example.com:443 (automatique)

Numéros de port courants

PortUtilisation
80HTTP (Web)
443HTTPS (Web sécurisé)
21FTP (Transfert de fichiers)
22SSH (Connexion à distance)
3000Serveur de développement (Node.js)
3306Base de données MySQL
5432PostgreSQL
8080HTTP alternatif

En développement ?

http://localhost:3000      # Serveur de développement React
http://localhost:8080 # Spring Boot
http://127.0.0.1:5000 # Flask/Python

4. Chemin (Path) 📂

Une page ou un dossier spécifique dans le site web

https://example.com/products/shoes/nike
└────────┬────────┘
Chemin

Structure du chemin

/products/shoes/nike
└┬┘ └┬┘ └┬┘
Catégorie Détail Marque

Pensez-y comme à une structure de dossiers réelle :

Site web
├── products/
│ ├── shoes/
│ │ ├── nike/
│ │ └── adidas/
│ └── clothes/
└── about/

Exemple réel

https://github.com/facebook/react
└──────┬──────┘
Chemin
/utilisateur/dépôt

5. Chaîne de requête (Query String) 🔍

Informations supplémentaires ou conditions de recherche

https://example.com/search?q=javascript&sort=popular&page=2
└──────────────┬──────────────┘
Chaîne de requête

Structure

?key1=value1&key2=value2&key3=value3
└┬┘ └──┬──┘ └──┬──┘ └──┬──┘
Début Premier Séparateur Troisième
(clé=valeur) (&) (clé=valeur)

Exemples d'utilisation réels

Recherche

https://google.com/search?q=javascript
└─────┬────┘
Terme de recherche: javascript

Filtrage

https://shop.com/products?category=shoes&color=red&size=10
└────────────┬────────────────┘
Catégorie:shoes, Couleur:red, Taille:10

Pagination

https://blog.com/posts?page=2&limit=20
└──────┬──────┘
Page 2, 20 par page

Remarque

Les caractères français ou spéciaux nécessitent un encodage :

Original: ?q=français
Encodé: ?q=fran%C3%A7ais
Astuce

Vous pouvez facilement encoder avec URL Encoder !

6. Hash/Fragment (Hash/Fragment) #️⃣

Un emplacement spécifique dans la page

https://example.com/docs#installation
└─────┬────┘
Hash

Utilisation

1. Navigation dans la page

<a href="#section1">Aller à la section 1</a>

<h2 id="section1">Section 1</h2>

2. SPA (Single Page Application)

https://app.com/#/home
https://app.com/#/profile
https://app.com/#/settings

Caractéristiques

  • Non envoyé au serveur
  • Utilisé uniquement par le navigateur
  • Navigation sans rechargement de la page

Exemples pratiques

Exemple 1 : Site de commerce 🛍️

https://shop.example.com/products/electronics/laptops?brand=apple&price=1000-2000&sort=price#reviews

Protocole: https
Domaine: shop.example.com
Chemin: /products/electronics/laptops
Chaîne de requête:
- brand=apple (Produits Apple uniquement)
- price=1000-2000 (Plage de prix)
- sort=price (Tri par prix)
Hash: #reviews (Aller à la section des avis)

Exemple 2 : Moteur de recherche 🔍

https://www.google.com/search?q=web+development&hl=fr&page=1

Protocole: https
Sous-domaine: www
Domaine: google.com
Chemin: /search
Chaîne de requête:
- q=web+development (Terme de recherche)
- hl=fr (Français)
- page=1 (Première page)

Exemple 3 : Vidéo YouTube 🎥

https://www.youtube.com/watch?v=dQw4w9WgXcQ&t=30s

Protocole: https
Domaine: www.youtube.com
Chemin: /watch
Chaîne de requête:
- v=dQw4w9WgXcQ (ID vidéo)
- t=30s (Lecture à partir de 30 secondes)

Utiliser les outils d'analyse d'URL

URL Params Parser

Dans URL Params Parser :

  • Collez une URL pour analyser automatiquement chaque partie
  • Affiche la liste des paramètres de la chaîne de requête
  • Traite automatiquement l'encodage/décodage

Questions fréquemment posées (FAQ)

Q1 : Puis-je omettre le www ?

R : Oui ! La tendance actuelle est d'omettre le www.

https://example.com  ✅
https://www.example.com ✅ (même site)

Q2 : Y a-t-il une limite de longueur d'URL ?

R : Techniquement, environ 2000 caractères est sûr. Mais plus court est meilleur !

Q3 : Les URL sont-elles sensibles à la casse ?

R : Cela dépend de la partie !

Domaine : insensible à la casse
Example.com = example.com ✅

Chemin : sensible à la casse (selon la configuration du serveur)
/About ≠ /about ⚠️

Q4 : Puis-je utiliser des caractères spéciaux ?

R : Seulement certains, la plupart nécessitent un encodage !

Caractères sûrs : A-Z a-z 0-9 - _ . ~
Encodage nécessaire : espace, français, ?, &, #, %, / etc.

Conseils pour créer de bonnes URL 💡

1. Court et clair

❌ https://example.com/p?id=12345&cat=3&subcategory=5
✅ https://example.com/products/shoes/nike-air

2. Utiliser des mots significatifs

❌ /page1.php
✅ /about-us

❌ /item?id=123
✅ /products/laptop-dell-xps

3. Utiliser des minuscules

❌ /Products/SHOES
✅ /products/shoes

4. Utiliser des tirets (-) (pas de tirets bas)

❌ /web_development
✅ /web-development

5. Supprimer les mots inutiles

❌ /and-the-product-is-shoes
✅ /products/shoes

Débogage d'URL

Ce qu'il faut vérifier lorsqu'une URL ne fonctionne pas :

Liste de contrôle

  1. ✅ Y a-t-il un protocole ? (https://)
  2. ✅ L'orthographe du domaine est-elle correcte ?
  3. ✅ Le chemin existe-t-il ?
  4. ✅ Le format de la chaîne de requête est-il correct ? (?key=value&key2=value2)
  5. ✅ Les caractères spéciaux sont-ils encodés ?

Utilisation des outils

Prochaines étapes 🚀

Si vous avez compris la structure d'une URL :

  1. Comprendre les requêtes/réponses HTTP - Comment échanger des données avec des URL
  2. URL Encoder - Pratiquer l'encodage/décodage d'URL
  3. URL Params Parser - Outil d'analyse d'URL
  4. API Tester - Faire des requêtes API avec des URL
  5. Qu'est-ce que l'encodage ? - En savoir plus sur l'encodage d'URL

Conclusion

Une URL est l'adresse d'Internet ! 🏠

Points à retenir :

  • Protocole : https:// (sécurisé) vs http:// (non sécurisé)
  • Domaine : nom du site web (example.com)
  • Port : généralement omis (443, 80)
  • Chemin : emplacement de la page (/products/shoes)
  • Chaîne de requête : informations supplémentaires (?color=red&size=10)
  • Hash : emplacement dans la page (#section1)

Comprendre la structure d'une URL rend le développement web beaucoup plus facile ! 🎉

Maintenant, vous pouvez comprendre ce que signifie chaque partie lorsque vous voyez une adresse de site web, n'est-ce pas ?