Liste des codes HTTP

Le protocole de communication informatique HTTP définit une liste de codes HTTP. Ces codes sont des numéros de 3 chiffres. La plupart des codes correspondent chacun à un type d'erreur, quelques-uns correspondent à un type de succès. Ces codes permettent aux logiciels client HTTP de déterminer automatiquement si une requête a réussi, et sinon de connaître le type d'erreur.

Exemple d'erreur 404 sur Wikipédia.

Ces codes d'état ont été successivement définis par la RFC 1945[1], puis la RFC 2068[2], puis la RFC 2616[3], en même temps que d’autres codes d'état, non normalisés mais très utilisés sur le Web. En 2014, ils ont été finalement spécifiés par la RFC 7231[4].

Structure des codes

Le premier chiffre est utilisé pour spécifier une des cinq catégories de réponse (informations, succès, redirection, erreur client et erreur serveur).

Les codes les plus courants sont :

  • 200 : succès de la requête ;
  • 301 et 302 : redirection, respectivement permanente et temporaire ;
  • 401 : utilisateur non authentifié ;
  • 403 : accès refusé ;
  • 404 : ressource non trouvée ;
  • 500, 502 et 503 : erreurs serveur ;
  • 504 : le serveur n'a pas répondu.

Certains codes ne sont pas encore utilisés, mais sont prévus pour une utilisation future. D'autres codes n'entraînent aucun affichage spécifique pour l’utilisateur, mais sont sous-entendus (par exemple, les codes 200 ou 304, jamais vus par le client car ils concernent la majorité des requêtes réussies).

Codes d'état

Les codes de la table ci-dessous marqués WebDAV ne sont pas spécifiés par le protocole HTTP mais par le protocole WebDAV qui est une extension de HTTP.

1xx - Information

Codes commençant par 1
Code Message Signification
100 Continue Attente de la suite de la requête.
101 Switching Protocols Acceptation du changement de protocole.
102 Processing WebDAV RFC 2518[5],[6]: Traitement en cours (évite que le client dépasse le temps d’attente limite).
103 Early Hints RFC 8297[7] : (Expérimental) Dans l'attente de la réponse définitive, le serveur retourne des liens que le client peut commencer à télécharger.

2xx - Succès

Codes commençant par 2
Code Message Signification
200 OK Requête traitée avec succès. La réponse dépendra de la méthode de requête utilisée.
201 Created Requête traitée avec succès et création d’un document.
202 Accepted Requête traitée, mais sans garantie de résultat.
203 Non-Authoritative Information Information retournée, mais générée par une source non certifiée.
204 No Content Requête traitée avec succès mais pas d’information à renvoyer.
205 Reset Content Requête traitée avec succès, la page courante peut être effacée.
206 Partial Content Une partie seulement de la ressource a été transmise.
207 Multi-Status WebDAV : Réponse multiple.
208 Already Reported WebDAV : Le document a été envoyé précédemment dans cette collection.
210 Content Different WebDAV : La copie de la ressource côté client diffère de celle du serveur (contenu ou propriétés).
226 IM Used RFC 3229[8] : Le serveur a accompli la requête pour la ressource, et la réponse est une représentation du résultat d'une ou plusieurs manipulations d'instances appliquées à l'instance actuelle.

3xx - Redirection

Codes commençant par 3
Code Message Signification
300 Multiple Choices L’URI demandée se rapporte à plusieurs ressources.
301 Moved Permanently Document déplacé de façon permanente.
302 Found Document déplacé de façon temporaire.
303 See Other La réponse à cette requête est ailleurs.
304 Not Modified Document non modifié depuis la dernière requête.
305 Use Proxy (depuis HTTP/1.1) La requête doit être ré-adressée au proxy.
306 Switch Proxy Code utilisé par une ancienne version de la RFC 2616[9], à présent réservé. Elle signifiait « Les requêtes suivantes doivent utiliser le proxy spécifié »[10].
307 Temporary Redirect La requête doit être redirigée temporairement vers l’URI spécifiée sans changement de méthode[11].
308 Permanent Redirect La requête doit être redirigée définitivement vers l’URI spécifiée sans changement de méthode[12].
310 Too many Redirects La requête doit être redirigée de trop nombreuses fois, ou est victime d’une boucle de redirection.

4xx - Erreur du client HTTP

Codes commençant par 4
Code Message Signification
400 Bad Request La syntaxe de la requête est erronée.
401 Unauthorized Une authentification est nécessaire pour accéder à la ressource.
402 Payment Required Paiement requis pour accéder à la ressource.
403 Forbidden Le serveur a compris la requête, mais refuse de l'exécuter. Contrairement à l'erreur 401, s'authentifier ne fera aucune différence. Sur les serveurs où l'authentification est requise, cela signifie généralement que l'authentification a été acceptée mais que les droits d'accès ne permettent pas au client d'accéder à la ressource.
404 Not Found Ressource non trouvée.
405 Method Not Allowed Méthode de requête non autorisée.
406 Not Acceptable La ressource demandée n'est pas disponible dans un format qui respecterait les en-têtes « Accept » de la requête.
407 Proxy Authentication Required Accès à la ressource autorisé par identification avec le proxy.
408 Request Time-out Temps d’attente d’une requête du client, écoulé côté serveur. D'après les spécifications HTTP : « Le client n'a pas produit de requête dans le délai que le serveur était prêt à attendre. Le client PEUT répéter la demande sans modifications à tout moment ultérieur »[13].
409 Conflict La requête ne peut être traitée à la suite d'un conflit avec l'état actuel du serveur.
410 Gone La ressource n'est plus disponible et aucune adresse de redirection n’est connue.
411 Length Required La longueur de la requête n’a pas été précisée.
412 Precondition Failed Préconditions envoyées par la requête non vérifiées.
413 Request Entity Too Large Traitement abandonné dû à une requête trop importante.
414 Request-URI Too Long URI trop longue.
415 Unsupported Media Type Format de requête non supporté pour une méthode et une ressource données.
416 Requested range unsatisfiable Champs d’en-tête de requête « range » incorrect.
417 Expectation failed Comportement attendu et défini dans l’en-tête de la requête insatisfaisante.
418 I’m a teapot « Je suis une théière » : Ce code est défini dans la RFC 2324[14] datée du , Hyper Text Coffee Pot Control Protocol.
421 Bad mapping / Misdirected Request La requête a été envoyée à un serveur qui n'est pas capable de produire une réponse (par exemple, car une connexion a été réutilisée).
422 Unprocessable entity WebDAV : L’entité fournie avec la requête est incompréhensible ou incomplète.
423 Locked WebDAV : L’opération ne peut avoir lieu car la ressource est verrouillée.
424 Method failure WebDAV : Une méthode de la transaction a échoué.
425 Too Early RFC 8470[15] : le serveur ne peut traiter la demande car elle risque d'être rejouée.
426 Upgrade Required RFC 2817[16] : Le client devrait changer de protocole, par exemple au profit de TLS/1.0.
428 Precondition Required RFC 6585[17] : La requête doit être conditionnelle.
429 Too Many Requests RFC 6585[18] : le client a émis trop de requêtes dans un délai donné.
431 Request Header Fields Too Large RFC 6585[18] : Les entêtes HTTP émises dépassent la taille maximale admise par le serveur.
449 Retry With Code défini par Microsoft. La requête devrait être renvoyée après avoir effectué une action.
450 Blocked by Windows Parental Controls Code défini par Microsoft. Cette erreur est produite lorsque les outils de contrôle parental de Windows sont activés et bloquent l’accès à la page.
451 Unavailable For Legal Reasons Ce code d'erreur indique que la ressource demandée est inaccessible pour des raisons d'ordre légal[19],[20].
456 Unrecoverable Error WebDAV : Erreur irrécupérable.
Codes 4xx étendus au serveur Nginx
Code Message Signification
444 No Response Indique que le serveur n'a retourné aucune information vers le client et a fermé la connexion. Visible seulement dans les journaux du serveur Nginx.
495 SSL Certificate Error Une extension de l'erreur 400 Bad Request, utilisée lorsque le client a fourni un certificat invalide.
496 SSL Certificate Required Une extension de l'erreur 400 Bad Request, utilisée lorsqu'un certificat client requis n'est pas fourni.
497 HTTP Request Sent to HTTPS Port Une extension de l'erreur 400 Bad Request, utilisée lorsque le client envoie une requête HTTP vers le port 443 normalement destiné aux requêtes HTTPS.
498 Token expired/invalid Le jeton a expiré ou est invalide.
499 Client Closed Request Le client a fermé la connexion avant de recevoir la réponse. Cette erreur se produit quand le traitement est trop long côté serveur[21].

5xx - Erreur du serveur / du serveur d'application

Codes commençant par 5
Code Message Signification
500 Internal Server Error Erreur interne du serveur.
501 Not Implemented Fonctionnalité réclamée non supportée par le serveur.
502 Bad Gateway ou Proxy Error En agissant en tant que serveur proxy ou passerelle, le serveur a reçu une réponse invalide depuis le serveur distant.
503 Service Unavailable Service temporairement indisponible ou en maintenance.
504 Gateway Time-out Temps d’attente d’une réponse d’un serveur à un serveur intermédiaire écoulé.
505 HTTP Version not supported Version HTTP non gérée par le serveur.
506 Variant Also Negotiates RFC 2295[22] : Erreur de négociation. Transparent content negociation.
507 Insufficient storage WebDAV : Espace insuffisant pour modifier les propriétés ou construire la collection.
508 Loop detected WebDAV : Boucle dans une mise en relation de ressources (RFC 5842[23]).
509 Bandwidth Limit Exceeded Utilisé par de nombreux serveurs pour indiquer un dépassement de quota.
510 Not extended RFC 2774[24] : La requête ne respecte pas la politique d'accès aux ressources HTTP étendues.
511 Network authentication required RFC 6585[18] : Le client doit s'authentifier pour accéder au réseau. Utilisé par les portails captifs pour rediriger les clients vers la page d'authentification.
Codes 5xx étendus au mandataire Cloudflare
Code Message Signification
520 Unknown Error L'erreur 520 est utilisé en tant que réponse générique lorsque le serveur d'origine retourne un résultat imprévu.
521 Web Server Is Down Le serveur a refusé la connexion depuis Cloudflare.
522 Connection Timed Out Cloudflare n'a pas pu négocier un TCP handshake avec le serveur d'origine.
523 Origin Is Unreachable Cloudflare n'a pas réussi à joindre le serveur d'origine. Cela peut se produire en cas d'échec de résolution de nom de serveur DNS.
524 A Timeout Occurred Cloudflare a établi une connexion TCP avec le serveur d'origine mais n'a pas reçu de réponse HTTP avant l'expiration du délai de connexion.
525 SSL Handshake Failed Cloudflare n'a pas pu négocier un SSL/TLS handshake avec le serveur d'origine.
526 Invalid SSL Certificate Cloudflare n'a pas pu valider le certificat SSL présenté par le serveur d'origine.
527 Railgun Error L'erreur 527 indique que la requête a dépassé le délai de connexion ou a échoué après que la connexion WAN a été établie.

Annexes

Articles connexes

Notes et références

  1. (en) « Hypertext Transfer Protocol -- HTTP/1.0 », Request for comments no 1945, .
  2. (en) « Hypertext Transfer Protocol -- HTTP/1.1 », Request for comments no 2068, .
  3. (en) « Hypertext Transfer Protocol -- HTTP/1.1 », Request for comments no 2616, .
  4. (en) « Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content », Request for comments no 7231, .
  5. (en) Request for comments no 2518.
  6. (en) Jensen, D. et Faizi, A., « HTTP Extensions for Distributed Authoring -- WEBDAV », sur tools.ietf.org (consulté le )
  7. (en) Request for comments no 8297.
  8. (en) Request for comments no 3229.
  9. (en) Request for comments no 2616.
  10. (en) Josh Cohen, « HTTP/1.1 305 and 306 Response Codes », sur tools.ietf.org, (consulté le )
  11. (en) « RFC 7231 - Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content », sur datatracker.ietf.org (consulté le )
  12. « RFC 7538 - The Hypertext Transfer Protocol Status Code 308 (Permanent Redirect) », sur datatracker.ietf.org (consulté le )
  13. « 408 », sur httpstatus.es (consulté le )
  14. (en) « Hyper Text Coffee Pot Control Protocol (HTCPCP/1.0) », Request for comments no 2324, .
  15. (en) Mark Nottingham et Martin Thomson, « Using Early Data in HTTP », sur tools.ietf.org (consulté le )
  16. (en) Request for comments no 2817.
  17. (en) « Additional HTTP Status Codes », Request for comments no 6585, .
  18. (en) Request for comments no 6585.
  19. « Erreur 451 : le nouveau code signalant la censure sur internet », sur www.clubic.com, (consulté le ).
  20. « Erreur 451 : le nouveau code HTTP pour exposer la censure du Web », sur www.zdnet.fr, (consulté le ).
  21. (en) « Re: Status Code 499 », sur Forum de Nginx (consulté le ).
  22. (en) Request for comments no 2295.
  23. (en) Request for comments no 5842.
  24. (en) Request for comments no 2774.
  • Portail de l’informatique
Cet article est issu de Wikipedia. Le texte est sous licence Creative Commons - Attribution - Partage dans les Mêmes. Des conditions supplémentaires peuvent s'appliquer aux fichiers multimédias.