HTTP - Guide rapide

Le protocole HTTP (Hypertext Transfer Protocol) est un protocole de niveau application pour les systèmes d'information distribués, collaboratifs et hypermédia. C'est la base de la communication de données pour le World Wide Web (c'est-à-dire Internet) depuis 1990. HTTP est un protocole générique et sans état qui peut être utilisé à d'autres fins aussi bien en utilisant l'extension de ses méthodes de demande, codes d'erreur et en-têtes.

Fondamentalement, HTTP est un protocole de communication basé sur TCP / IP, utilisé pour fournir des données (fichiers HTML, fichiers image, résultats de requêtes, etc.) sur le World Wide Web. Le port par défaut est TCP 80, mais d'autres ports peuvent être utilisés. Il fournit un moyen standardisé pour les ordinateurs de communiquer entre eux. La spécification HTTP spécifie comment les données de demande des clients seront construites et envoyées au serveur, et comment les serveurs répondront à ces demandes.

Caractéristiques de base

Les trois fonctionnalités de base suivantes font de HTTP un protocole simple mais puissant:

  • HTTP is connectionless:Le client HTTP ie. le navigateur lance une requête HTTP et après qu'une requête est faite, le client se déconnecte du serveur et attend une réponse. Le serveur traite la demande et rétablit la connexion avec le client pour renvoyer la réponse.

  • HTTP is media independent:Cela signifie que tout type de données peut être envoyé par HTTP tant que le client et le serveur savent comment gérer le contenu des données. Cela est nécessaire pour le client et le serveur pour spécifier le type de contenu à l'aide du type MIME approprié.

  • HTTP is stateless:Comme mentionné ci-dessus, HTTP est un protocole sans connexion et c'est un résultat direct que HTTP est un protocole sans état. Le serveur et le client ne se reconnaissent que lors d'une requête en cours. Ensuite, ils s'oublient tous les deux. En raison de cette nature du protocole, ni le client ni le navigateur ne peuvent conserver les informations entre les différentes requêtes sur les pages Web.

HTTP / 1.0 utilise une nouvelle connexion pour chaque échange de demande / réponse alors qu'une connexion HTTP / 1.1 peut être utilisée pour un ou plusieurs échanges de demande / réponse.

Architecture de base

Le diagramme suivant montre une architecture très basique d'une application Web et décrit l'emplacement de HTTP:

Le protocole HTTP est un protocole de demande / réponse basé sur une architecture client / serveur où le navigateur Web, les robots et les moteurs de recherche, etc. agissent comme des clients HTTP et le serveur Web agit comme un serveur.

Client

Le client HTTP envoie une demande au serveur sous la forme d'une méthode de demande, d'un URI et d'une version de protocole, suivie d'un message de type MIME contenant des modificateurs de demande, des informations sur le client et le contenu du corps possible via une connexion TCP / IP.

Serveur

Le serveur HTTP répond avec une ligne d'état, comprenant la version du protocole du message et un code de réussite ou d'erreur, suivi d'un message de type MIME contenant des informations sur le serveur, des méta-informations d'entité et un éventuel contenu de corps d'entité.

Ce chapitre va énumérer quelques-uns des paramètres de protocole HTTP importants et leur syntaxe de la manière dont ils sont utilisés dans la communication. Par exemple, le format de la date, le format de l'URL, etc. Cela vous aidera à construire vos messages de requête et de réponse lors de l'écriture de programmes client ou serveur HTTP. Vous verrez l'utilisation complète de ces paramètres dans les chapitres suivants tout en expliquant la structure des messages pour les requêtes et réponses HTTP.

Version HTTP

HTTP utilise un <major>.<minor>schéma de numérotation pour indiquer les versions du protocole. La version d'un message HTTP est indiquée par un champ HTTP-Version dans la première ligne. Voici la syntaxe générale de la spécification du numéro de version HTTP:

HTTP-Version   = "HTTP" "/" 1*DIGIT "." 1*DIGIT

Exemple

HTTP/1.0

or

HTTP/1.1

Identificateurs de ressources uniformes (URI)

Uniform Resource Identifiers (URI) est simplement une chaîne formatée, insensible à la casse, contenant le nom, l'emplacement, etc. pour identifier une ressource, par exemple un site Web, un service Web, etc. Une syntaxe générale d'URI utilisée pour HTTP est la suivante:

URI = "http:" "//" host [ ":" port ] [ abs_path [ "?" query ]]

Ici si le port est vide ou non fourni, le port 80 est supposé pour HTTP et un abs_path équivaut à un abs_pathde "/". Les personnages autres que ceux dureserved et unsafe les ensembles sont équivalents à leur codage ""% "HEX HEX".

Exemple

Les deux URI suivants sont équivalents:

http://abc.com:80/~smith/home.html
http://ABC.com/%7Esmith/home.html
http://ABC.com:/%7esmith/home.html

Formats de date / heure

Tous les horodatages HTTP DOIVENT être représentés en heure moyenne de Greenwich (GMT), sans exception. Les applications HTTP sont autorisées à utiliser l'une des trois représentations suivantes des horodatages:

Sun, 06 Nov 1994 08:49:37 GMT  ; RFC 822, updated by RFC 1123
Sunday, 06-Nov-94 08:49:37 GMT ; RFC 850, obsoleted by RFC 1036
Sun Nov  6 08:49:37 1994       ; ANSI C's asctime() format

Jeux de caractères

Vous utilisez un jeu de caractères pour spécifier les jeux de caractères que le client préfère. Plusieurs jeux de caractères peuvent être répertoriés séparés par des virgules. Si aucune valeur n'est spécifiée, la valeur par défaut est US-ASCII.

Exemple

Voici les jeux de caractères valides:

US-ASCII

or

ISO-8859-1

or 

ISO-8859-7

Codages de contenu

Les valeurs d'écodage du contenu indiquent qu'un algorithme de codage a été utilisé pour coder le contenu avant de le transmettre sur le réseau. Les codages de contenu sont principalement utilisés pour permettre à un document d'être compressé ou autrement utilement transformé sans perdre son identité.

Toutes les valeurs de codage de contenu sont insensibles à la casse. HTTP / 1.1 utilise des valeurs de codage de contenu dans les champs d'en-tête Accept-Encoding et Content-Encoding que nous verrons dans les chapitres suivants.

Exemple

Voici les schémas d'encodage valides:

Accept-encoding: gzip

or

Accept-encoding: compress

or 

Accept-encoding: deflate

Types de médias

HTTP utilise les types de média Internet dans le Content-Type et Acceptchamps d'en-tête afin de fournir un typage de données ouvert et extensible et une négociation de type. Toutes les valeurs de type de média sont enregistrées auprès de l’Internet Assigned Number Authority ((IANA). Voici une syntaxe générale pour spécifier le type de média:

media-type     = type "/" subtype *( ";" parameter )

Les noms d'attributs de type, sous-type et paramètre sont insensibles à la casse.

Exemple

Accept: image/gif

Balises de langue

HTTP utilise des balises de langue dans Accept-Language et Content-Languagedes champs. Une balise de langue est composée d'une ou plusieurs parties: Une balise de langue principale et une série éventuellement vide de sous-balises:

language-tag  = primary-tag *( "-" subtag )

Les espaces blancs ne sont pas autorisés dans la balise et toutes les balises sont insensibles à la casse.

Exemple

Exemples de balises:

en, en-US, en-cockney, i-cherokee, x-pig-latin

Où une étiquette primaire à deux lettres est une abréviation de langue ISO-639 et toute sous-étiquette initiale à deux lettres est un code de pays ISO-3166.

HTTP est basé sur un modèle d'architecture client-serveur et un protocole de demande / réponse sans état qui fonctionne en échangeant des messages via une connexion TCP / IP fiable.

Un "client" HTTP est un programme (navigateur Web ou tout autre client) qui établit une connexion à un serveur dans le but d'envoyer un ou plusieurs messages de requête HTTP. Un "serveur" HTTP est un programme (généralement un serveur Web comme Apache Web Server ou Internet Information Services IIS, etc.) qui accepte les connexions afin de servir les requêtes HTTP en envoyant des messages de réponse HTTP.

HTTP utilise l'identificateur de ressource uniforme (URI) pour identifier une ressource donnée et établir une connexion. Une fois la connexion établie,HTTP messagessont transmis dans un format similaire à celui utilisé par la messagerie Internet [RFC5322] et les extensions de messagerie Internet polyvalentes (MIME) [RFC2045]. Ces messages sont constitués derequests du client au serveur et responses du serveur au client qui aura le format suivant:

HTTP-message   = <Request> | <Response> ; HTTP/1.1 messages

La requête HTTP et la réponse HTTP utilisent un format de message générique de la RFC 822 pour transférer les données requises. Ce format de message générique se compose des quatre éléments suivants.


     
  • A Start-line
  • Zero or more header fields followed by CRLF
  • An empty line (i.e., a line with nothing preceding the CRLF) indicating the end of the header fields
  • Optionally a message-body

La section suivante expliquera chacune des entités utilisées dans le message HTTP.

Ligne de début de message

Une ligne de départ aura la syntaxe générique suivante:

start-line = Request-Line | Status-Line

Nous discuterons respectivement de Request-Line et Status-Line tout en discutant des messages de requête HTTP et de réponse HTTP. Pour l'instant, voyons les exemples de ligne de départ en cas de requête et de réponse:

GET /hello.htm HTTP/1.1     (This is Request-Line sent by the client)

HTTP/1.1 200 OK             (This is Status-Line sent by the server)

Champs d'en-tête

Les champs HTTP deader fournissent les informations requises sur la demande ou la réponse, ou sur l'objet envoyé dans le corps du message. Il existe quatre types d'en-têtes de message HTTP suivants:

  • General-header: Ces champs d'en-tête ont une applicabilité générale pour les messages de demande et de réponse.

  • Request-header: Ces champs d'en-tête s'appliquent uniquement aux messages de demande.

  • Response-header: Ces champs d'en-tête s'appliquent uniquement aux messages de réponse.

  • Entity-header: Ces champs d'en-tête définissent des méta-informations sur le corps de l'entité ou, si aucun corps n'est présent

Tous les en-têtes mentionnés ci-dessus suivent le même format générique et chacun des champs d'en-tête se compose d'un nom suivi de deux points (:) et la valeur du champ comme suit:

message-header = field-name ":" [ field-value ]

Voici les exemples de différents champs d'en-tête:

User-Agent: curl/7.16.3 libcurl/7.16.3 OpenSSL/0.9.7l zlib/1.2.3
Host: www.example.com
Accept-Language: en, mi
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Accept-Ranges: bytes
Content-Length: 51
Vary: Accept-Encoding
Content-Type: text/plain

Corps du message

La partie du corps du message est facultative pour un message HTTP, mais si elle est disponible, elle est utilisée pour transporter le corps d'entité associé à la demande ou à la réponse. Si le corps de l'entité est associé, alors généralementContent-Type et Content-Length les lignes d'en-tête spécifient la nature du corps associé.

Un corps de message est celui qui transporte les données de demande HTTP réelles (y compris les données de formulaire et téléchargées, etc.) et les données de réponse HTTP du serveur (y compris les fichiers, les images, etc.) Voici un contenu simple du corps d'un message:

<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>

Un client HTTP envoie une requête HTTP à un serveur sous la forme d'un message de requête qui comprend le format suivant:


     
  • A Request-line
  • Zero or more header (General|Request|Entity) fields followed by CRLF
  • An empty line (i.e., a line with nothing preceding the CRLF) indicating the end of the header fields
  • Optionally a message-body

La section suivante expliquera chacune des entités utilisées dans le message HTTP.

Ligne de demande de message

La Request-Line commence par un jeton de méthode, suivi de Request-URI et de la version du protocole, et se termine par CRLF. Les éléments sont séparés par des caractères d'espace SP.

Request-Line   = Method SP Request-URI SP HTTP-Version CRLF

Discutons de chacune des parties mentionnées dans Request-Line.

Méthode de demande

La demande Method indique la méthode à exécuter sur la ressource identifiée par le Request-URI. La méthode est sensible à la casse et doit toujours être mentionnée en majuscules. Voici les méthodes prises en charge dans HTTP / 1.1

SN Méthode et description
1 GET
La méthode GET est utilisée pour récupérer les informations du serveur donné en utilisant un URI donné. Les requêtes utilisant GET ne doivent récupérer que des données et ne doivent avoir aucun autre effet sur les données.
2 HEAD
Identique à GET, mais ne transférez que la ligne d'état et la section d'en-tête.
3 POST
Une requête POST est utilisée pour envoyer des données au serveur, par exemple des informations client, le téléchargement de fichiers, etc. à l'aide de formulaires HTML.
4 PUT
Remplacez toutes les représentations actuelles de la ressource cible par le contenu téléchargé.
5 DELETE
Supprimez toutes les représentations actuelles de la ressource cible fournies par l'URI.
6 CONNECT
Établissez un tunnel vers le serveur identifié par un URI donné.
sept OPTIONS
Décrivez les options de communication pour la ressource cible.
8 TRACE
Effectuez un test de bouclage des messages le long du chemin vers la ressource cible.

Request-URI

Le Request-URI est un identificateur de ressource uniforme et identifie la ressource sur laquelle appliquer la demande. Voici les formulaires les plus couramment utilisés pour spécifier un URI:

Request-URI = "*" | absoluteURI | abs_path | authority
SN Méthode et description
1 L'astérisque *est utilisé lorsque la requête HTTP ne s'applique pas à une ressource particulière, mais au serveur lui-même, et n'est autorisée que lorsque la méthode utilisée ne s'applique pas nécessairement à une ressource. Par exemple:

OPTIONS * HTTP/1.1

2 le absoluteURIest utilisé lorsque la requête HTTP est adressée à un proxy. Le proxy est invité à transférer la demande ou à la traiter à partir d'un cache valide et à renvoyer la réponse. Par exemple:

GET http://www.w3.org/pub/WWW/TheProject.html HTTP/1.1

3 La forme la plus courante de Request-URI est celle utilisée pour identifier une ressource sur un serveur ou une passerelle d'origine. Par exemple, un client souhaitant récupérer la ressource ci-dessus directement depuis le serveur d'origine créerait une connexion TCP au port 80 de l'hôte "www.w3.org" et enverrait les lignes:

GET /pub/WWW/TheProject.html HTTP/1.1
Host: www.w3.org

Notez que le chemin absolu ne peut pas être vide; si aucun n'est présent dans l'URI d'origine, il DOIT être donné comme "/" (la racine du serveur)

Demander des champs d'en-tête

Nous étudierons l'en-tête général et l'en-tête d'entité dans un chapitre séparé lorsque nous apprendrons les champs d'en-tête HTTP. Pour l'instant, vérifions quels sont les champs d'en-tête de demande.

Les champs d'en-tête de demande permettent au client de transmettre des informations supplémentaires sur la demande et sur le client lui-même au serveur. Ces champs agissent comme des modificateurs de demande et il existe des champs d'en-tête de demande importants suivants qui peuvent être utilisés en fonction des besoins.

  • Accept-Charset

  • Accept-Encoding

  • Accept-Language

  • Authorization

  • Expect

  • From

  • Host

  • If-Match

  • If-Modified-Since

  • If-None-Match

  • If-Range

  • If-Unmodified-Since

  • Max-Forwards

  • Proxy-Authorization

  • Range

  • Referer

  • TE

  • User-Agent

Vous pouvez introduire vos champs personnalisés au cas où vous allez écrire votre propre client et serveur Web personnalisés.

Demander des exemples de message

Maintenant, mettons tout cela ensemble pour former une requête HTTP à récupérer hello.htm page du serveur Web s'exécutant sur tutorialspoint.com

GET /hello.htm HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Ici, nous n'envoyons aucune donnée de requête au serveur car nous récupérons une page HTML de plan du serveur. La connexion est un en-tête général utilisé ici et le reste des en-têtes sont des en-têtes de demande. Voici un autre exemple où nous envoyons des données de formulaire au serveur à l'aide du corps du message de requête:

POST /cgi-bin/process.cgi HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Content-Type: application/x-www-form-urlencoded
Content-Length: length
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

licenseID=string&content=string&/paramsXML=string

Ici, l'URL /cgi-bin/process.cgi sera utilisée pour traiter les données transmises et en conséquence une réponse sera réaccordée. Icicontent-type indique au serveur que les données transmises sont de simples données de formulaire Web et lengthsera la longueur réelle des données placées dans le corps du message. L'exemple suivant montre comment vous pouvez transmettre le plan XML à votre serveur Web:

POST /cgi-bin/process.cgi HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Content-Type: text/xml; charset=utf-8
Content-Length: length
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

<?xml version="1.0" encoding="utf-8"?>
<string xmlns="http://clearforest.com/">string</string>

Après avoir reçu et interprété un message de requête, un serveur répond par un message de réponse HTTP:


     
  • A Status-line
  • Zero or more header (General|Response|Entity) fields followed by CRLF
  • An empty line (i.e., a line with nothing preceding the CRLF) indicating the end of the header fields
  • Optionally a message-body

La section suivante expliquera chacune des entités utilisées dans le message HTTP.

Ligne d'état du message

La ligne d'état composée de la version du protocole suivie d'un code d'état numérique et de sa phrase textuelle associée. Les éléments sont séparés par des caractères d'espace SP.

Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF

Discutons de chacune des parties mentionnées dans Status-Line.

Version HTTP

Un serveur prenant en charge HTTP version 1.1 renverra les informations de version suivantes:

HTTP-Version = HTTP/1.1

Code d'état

L'élément Status-Code est un entier à 3 chiffres où le premier chiffre du Status-Code définit la classe de réponse et les deux derniers chiffres n'ont aucun rôle de catégorisation. Il y a 5 valeurs pour le premier chiffre:

SN Code et description
1 1xx: Informational
Cela signifie une demande reçue et un processus continu.
2 2xx: Success
Cela signifie que l'action a été reçue, comprise et acceptée avec succès.
3 3xx: Redirection
Cela signifie que des mesures supplémentaires doivent être prises afin de terminer la demande.
4 4xx: Client Error
Cela signifie que la requête contient une mauvaise syntaxe ou ne peut pas être satisfaite
5 5xx: Server Error
Le serveur n'a pas réussi à répondre à une demande apparemment valide

Les codes d'état HTTP sont extensibles et les applications HTTP ne sont pas obligées de comprendre la signification de tous les codes d'état enregistrés. Une liste de tous les codes d'état a été donnée dans un chapitre séparé pour votre référence.

Champs d'en-tête de réponse

Nous étudierons l'en-tête général et l'en-tête d'entité dans un chapitre séparé lorsque nous apprendrons les champs d'en-tête HTTP. Pour l'instant, vérifions ce que sont les champs d'en-tête de réponse.

Les champs d'en-tête de réponse permettent au serveur de transmettre des informations supplémentaires sur la réponse qui ne peuvent pas être placées dans la ligne d'état. Ces champs d'en-tête donnent des informations sur le serveur et sur l'accès supplémentaire à la ressource identifiée par Request-URI.

  • Accept-Ranges

  • Age

  • ETag

  • Location

  • Proxy-Authenticate

  • Retry-After

  • Server

  • Vary

  • WWW-Authenticate

Vous pouvez introduire vos champs personnalisés au cas où vous allez écrire votre propre client et serveur Web personnalisés.

Exemples de messages de réponse

Maintenant, mettons tout cela ensemble pour former une réponse HTTP pour une requête à récupérer hello.htm page du serveur Web s'exécutant sur tutorialspoint.com

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
Content-Length: 88
Content-Type: text/html
Connection: Closed

<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>

Voici un exemple de message de réponse HTTP indiquant une condition d'erreur lorsque le serveur Web n'a pas pu trouver la page demandée:

HTTP/1.1 404 Not Found
Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Connection: Closed
Content-Type: text/html; charset=iso-8859-1
   
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head>
   <title>404 Not Found</title>
</head>
<body>
   <h1>Not Found</h1>
   <p>The requested URL /t.html was not found on this server.</p>
</body>
</html>

Voici un exemple de message de réponse HTTP indiquant une condition d'erreur lorsque le serveur Web a rencontré une version HTTP incorrecte dans une requête HTTP donnée:

HTTP/1.1 400 Bad Request
Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Content-Type: text/html; charset=iso-8859-1
Connection: Closed
   
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head>
   <title>400 Bad Request</title>
</head>
<body>
   <h1>Bad Request</h1>
   <p>Your browser sent a request that this server could not understand.<p>
   <p>The request line contained invalid characters following the protocol string.<p>
</body>
</html>

L'ensemble des méthodes courantes pour HTTP / 1.1 est défini ci-dessous et cet ensemble peut être étendu en fonction des besoins. Ces noms de méthodes sont sensibles à la casse et doivent être utilisés en majuscules.

SN Méthode et description
1 GET
La méthode GET est utilisée pour récupérer les informations du serveur donné en utilisant un URI donné. Les requêtes utilisant GET ne doivent récupérer que des données et ne doivent avoir aucun autre effet sur les données.
2 HEAD
Identique à GET, mais ne transférez que la ligne d'état et la section d'en-tête.
3 POST
Une requête POST est utilisée pour envoyer des données au serveur, par exemple des informations client, le téléchargement de fichiers, etc. à l'aide de formulaires HTML.
4 PUT
Remplacez toutes les représentations actuelles de la ressource cible par le contenu téléchargé.
5 DELETE
Supprimez toutes les représentations actuelles de la ressource cible fournies par l'URI.
6 CONNECT
Établissez un tunnel vers le serveur identifié par un URI donné.
sept OPTIONS
Décrivez les options de communication pour la ressource cible.
8 TRACE
Effectuez un test de bouclage des messages le long du chemin vers la ressource cible.

GET, méthode

Une requête GET récupère les données d'un serveur Web en spécifiant des paramètres dans la partie URL de la requête. C'est la principale méthode utilisée pour la récupération de documents. Voici un exemple simple qui utilise la méthode GET pour récupérer hello.htm:

GET /hello.htm HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Voici une réponse du serveur à la demande GET ci-dessus:

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Vary: Authorization,Accept
Accept-Ranges: bytes
Content-Length: 88
Content-Type: text/html
Connection: Closed

<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>

HEAD, méthode

La méthode HEAD est fonctionnellement similaire à GET, sauf que le serveur répond avec une ligne de réponse et des en-têtes, mais pas de corps d'entité. Voici un exemple simple qui utilise la méthode HEAD pour récupérer les informations d'en-tête sur hello.htm:

HEAD /hello.htm HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Voici une réponse du serveur à la demande GET ci-dessus:

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Vary: Authorization,Accept
Accept-Ranges: bytes
Content-Length: 88
Content-Type: text/html
Connection: Closed

Vous pouvez remarquer qu'ici le serveur n'envoie aucune donnée après l'en-tête.

Méthode POST

La méthode POST est utilisée lorsque vous souhaitez envoyer des données au serveur, par exemple une mise à jour de fichier, des données de formulaire, etc. Voici un exemple simple qui utilise la méthode POST pour envoyer des données de formulaire au serveur qui seront traitées par un process.cgi et enfin une réponse sera retournée:

POST /cgi-bin/process.cgi HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Content-Type: text/xml; charset=utf-8
Content-Length: 88
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

<?xml version="1.0" encoding="utf-8"?>
<string xmlns="http://clearforest.com/">string</string>

Le script côté serveur process.cgi traite les données transmises et envoie la réponse suivante:

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Vary: Authorization,Accept
Accept-Ranges: bytes
Content-Length: 88
Content-Type: text/html
Connection: Closed

<html>
<body>
<h1>Request Processed Successfully</h1>
</body>
</html>

Méthode PUT

La méthode PUT est utilisée pour demander au serveur de stocker le corps d'entité inclus à un emplacement spécifié par l'URL donnée. L'exemple suivant demande au serveur d'enregistrer le corps d'entité donné danshello.htm à la racine du serveur:

PUT /hello.htm HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Connection: Keep-Alive
Content-type: text/html
Content-Length: 182

<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>

Le serveur stockera le corps d'entité donné dans hello.htm fichier et enverra la réponse suivante au client:

HTTP/1.1 201 Created
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Content-type: text/html
Content-length: 30
Connection: Closed

<html>
<body>
<h1>The file was created.</h1>
</body>
</html>

DELETE, méthode

La méthode DELETE est utilisée pour demander au serveur de supprimer le fichier à un emplacement spécifié par l'URL donnée. L'exemple suivant demande au serveur de supprimer le fichier donnéhello.htm à la racine du serveur:

DELETE /hello.htm HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Connection: Keep-Alive

Le serveur supprimera le fichier mentionné hello.htm et enverra la réponse suivante au client:

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Content-type: text/html
Content-length: 30
Connection: Closed

<html>
<body>
<h1>URL deleted.</h1>
</body>
</html>

CONNECT, méthode

La méthode CONNECT est utilisée par le client pour établir une connexion réseau à un serveur Web via HTTP. L'exemple suivant demande une connexion avec un serveur Web s'exécutant sur l'hôte tutorialspoint.com:

CONNECT www.tutorialspoint.com HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)

La connexion est établie avec le serveur et la réponse suivante est renvoyée au client:

HTTP/1.1 200 Connection established
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)

OPTIONS, méthode

La méthode OPTIONS est utilisée par le client pour découvrir quelles sont les méthodes HTTP et autres options prises en charge par un serveur Web. Le client peut spécifier une URL pour la méthode OPTIONS ou un astérisque (*) pour désigner l'ensemble du serveur. L'exemple suivant demande une liste des méthodes prises en charge par un serveur Web s'exécutant sur tutorialspoint.com:

OPTIONS * HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)

Le serveur enverra des informations en fonction de la configuration actuelle du serveur, par exemple:

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Allow: GET,HEAD,POST,OPTIONS,TRACE
Content-Type: httpd/unix-directory

TRACE, méthode

La méthode TRACE est utilisée pour renvoyer le contenu d'une requête HTTP au demandeur qui peut être utilisée à des fins de débogage au moment du développement. L'exemple suivant montre l'utilisation de la méthode TRACE:

TRACE / HTTP/1.1
Host: www.tutorialspoint.com
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)

Le serveur enverra le message suivant en réponse à la demande ci-dessus:

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Content-Type: message/http
Content-Length: 39
Connection: Closed

TRACE / HTTP/1.1
Host: www.tutorialspoint.com
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)

L'élément Status-Code dans une réponse de serveur est un entier à 3 chiffres où le premier chiffre du Status-Code définit la classe de réponse et les deux derniers chiffres n'ont aucun rôle de catégorisation. Il y a 5 valeurs pour le premier chiffre:

SN Code et description
1 1xx: Informational
Cela signifie une demande reçue et un processus continu.
2 2xx: Success
Cela signifie que l'action a été reçue, comprise et acceptée avec succès.
3 3xx: Redirection
Cela signifie que des mesures supplémentaires doivent être prises afin de terminer la demande.
4 4xx: Client Error
Cela signifie que la requête contient une mauvaise syntaxe ou ne peut pas être satisfaite
5 5xx: Server Error
Le serveur n'a pas réussi à répondre à une demande apparemment valide

Les codes d'état HTTP sont extensibles et les applications HTTP ne sont pas obligées de comprendre la signification de tous les codes d'état enregistrés. Voici une liste de tous les codes d'état.

1xx: Informations

Message: La description:
100 Continuer Seule une partie de la demande a été reçue par le serveur, mais tant qu'elle n'a pas été rejetée, le client doit continuer avec la demande
101 Protocoles de commutation Le protocole de commutation du serveur

2xx: réussi

Message: La description:
200 OK La demande est OK
201 Créé La demande est terminée et une nouvelle ressource est créée 
202 Accepté La demande est acceptée pour le traitement, mais le traitement n'est pas terminé
203 Informations ne faisant pas autorité Les informations de l'en-tête d'entité proviennent d'une copie locale ou tierce et non du serveur d'origine.
204 Pas de contenu Un code d'état et un en-tête sont donnés dans la réponse, mais il n'y a pas de corps d'entité dans la réponse.
205 Réinitialiser le contenu Le navigateur doit effacer le formulaire utilisé pour cette transaction pour une entrée supplémentaire.
206 Contenu partiel Le serveur renvoie des données partielles de la taille demandée. Utilisé en réponse à une demande spécifiant un en- tête Range . Le serveur doit spécifier la plage incluse dans la réponse avec l'en - tête Content-Range .

3xx: redirection

Message: La description:
300 choix multiples Une liste de liens. L'utilisateur peut sélectionner un lien et accéder à cet emplacement. Maximum cinq adresses  
301 Déménagé Définitivement La page demandée a été déplacée vers une nouvelle URL 
302 Trouvés La page demandée a été déplacée temporairement vers une nouvelle URL 
303 Voir Autre La page demandée se trouve sous une URL différente 
304 Non modifié Il s'agit du code de réponse à un en - tête If-Modified-Since ou If-None-Match , où l'URL n'a pas été modifiée depuis la date spécifiée.
305 Utiliser un proxy L'URL demandée doit être accessible via le proxy mentionné dans l'en- tête Location .
306 inutilisé Ce code était utilisé dans une version précédente. Il n'est plus utilisé, mais le code est réservé
307 Redirection temporaire La page demandée a été déplacée temporairement vers une nouvelle URL

4xx: Erreur client

Message: La description:
400 Mauvaise demande Le serveur n'a pas compris la demande
401 Non autorisé La page demandée a besoin d'un nom d'utilisateur et d'un mot de passe
402 Paiement requis Vous ne pouvez pas encore utiliser ce code
403 Interdit L'accès à la page demandée est interdit
404 introuvable Le serveur ne trouve pas la page demandée
Méthode 405 non autorisée La méthode spécifiée dans la demande n'est pas autorisée
406 Non acceptable Le serveur ne peut générer qu'une réponse qui n'est pas acceptée par le client
Authentification proxy 407 requise Vous devez vous authentifier auprès d'un serveur proxy avant que cette demande puisse être servie
408 Délai d'expiration de la demande La demande a pris plus de temps que le serveur était prêt à attendre
409 Conflit La demande n'a pas pu être traitée en raison d'un conflit
410 disparu La page demandée n'est plus disponible 
411 Longueur requise Le "Content-Length" n'est pas défini. Le serveur n'acceptera pas la demande sans elle 
412 La condition préalable a échoué La condition préalable donnée dans la requête évaluée à false par le serveur
413 Entité de demande trop grande Le serveur n'acceptera pas la demande, car l'entité de demande est trop grande
414 URL de requête trop longue Le serveur n'acceptera pas la demande, car l'URL est trop longue. Se produit lorsque vous convertissez une requête «post» en une requête «get» avec une longue requête d'informations 
415 Type de support non pris en charge Le serveur n'acceptera pas la demande, car le type de média n'est pas pris en charge 
416 Gamme demandée non satisfaisante La plage d'octets demandée n'est pas disponible et est hors limites.
417 L'attente a échoué L'attente donnée dans un champ d'en-tête de demande Expect n'a pas pu être satisfaite par ce serveur.

5xx: Erreur de serveur

Message: La description:
500 Erreur de serveur interne La demande n'a pas été complétée. Le serveur a rencontré une condition inattendue
501 non mis en œuvre La demande n'a pas été complétée. Le serveur ne prend pas en charge la fonctionnalité requise
502 Mauvaise passerelle La demande n'a pas été complétée. Le serveur a reçu une réponse non valide du serveur en amont
503 Service Indisponible La demande n'a pas été complétée. Le serveur est temporairement en surcharge ou en panne
504 portail expiré La passerelle a expiré
505 Version HTTP non prise en charge Le serveur ne prend pas en charge la version "protocole http"

Les champs HTTP deader fournissent les informations requises sur la demande ou la réponse, ou sur l'objet envoyé dans le corps du message. Il existe quatre types d'en-têtes de message HTTP suivants:

  • General-header: Ces champs d'en-tête ont une applicabilité générale pour les messages de demande et de réponse.

  • Client Request-header: Ces champs d'en-tête s'appliquent uniquement aux messages de demande.

  • Server Response-header: Ces champs d'en-tête s'appliquent uniquement aux messages de réponse.

  • Entity-header: Ces champs d'en-tête définissent des méta-informations sur le corps de l'entité ou, si aucun corps n'est présent

En-têtes généraux

Contrôle du cache

Le champ d'en-tête général Cache-Control est utilisé pour spécifier des directives qui DOIVENT être respectées par tout le système de mise en cache. Voici la syntaxe:

Cache-Control : cache-request-directive|cache-response-directive

Un client ou serveur HTTP peut utiliser le Cache-controlen-tête général pour spécifier les paramètres du cache ou pour demander certains types de documents du cache. Les directives de mise en cache sont spécifiées dans une liste séparée par des virgules. Par exemple:

Cache-control: no-cache

Les directives de requête de cache importantes suivantes peuvent être utilisées par le client dans sa requête HTTP:

SN Directive et description de la demande de cache
1 no-cache
Un cache ne doit pas utiliser la réponse pour satisfaire une demande ultérieure sans une revalidation réussie avec le serveur d'origine.
2 no-store
Le cache ne doit rien stocker sur la demande du client ou la réponse du serveur.
3 max-age = seconds
Indique que le client est prêt à accepter une réponse dont l'âge n'est pas supérieur au temps spécifié en secondes.
4 max-stale [ = seconds ]
Indique que le client est prêt à accepter une réponse qui a dépassé son délai d'expiration. Si des secondes sont données, elles ne doivent pas être expirées de plus de ce temps.
5 min-fresh = seconds
Indique que le client est prêt à accepter une réponse dont la durée de vie d'actualisation n'est pas inférieure à son âge actuel plus la durée spécifiée en secondes.
6 no-transform
Ne convertissez pas le corps de l'entité.
sept only-if-cached
Ne récupérez pas de nouvelles données. Le cache peut envoyer un document uniquement s'il se trouve dans le cache et ne doit pas contacter le serveur d'origine pour voir si une copie plus récente existe.

Les directives de réponse de cache importantes suivantes peuvent être utilisées par le serveur dans sa réponse HTTP:

SN Directive et description de la demande de cache
1 public
Indique que la réponse peut être mise en cache par n'importe quel cache.
2 private
Indique que tout ou partie du message de réponse est destiné à un seul utilisateur et ne doit pas être mis en cache par un cache partagé.
3 no-cache
Un cache ne doit pas utiliser la réponse pour satisfaire une demande ultérieure sans une revalidation réussie avec le serveur d'origine.
4 no-store
Le cache ne doit rien stocker sur la demande du client ou la réponse du serveur.
5 no-transform
Ne convertissez pas le corps de l'entité.
6 must-revalidate
Le cache doit vérifier l'état des documents périmés avant de l'utiliser et un document périmé ne doit pas être utilisé.
sept proxy-revalidate
La directive proxy-revalidate a la même signification que la directive must-revalidate, sauf qu'elle ne s'applique pas aux caches d'agent utilisateur non partagés.
8 max-age = seconds
Indique que le client est prêt à accepter une réponse dont l'âge n'est pas supérieur au temps spécifié en secondes.
9 s-maxage = seconds
L'âge maximum spécifié par cette directive remplace l'âge maximum spécifié par la directive max-age ou par l'en-tête Expires. La directive s-maxage est toujours ignorée par un cache privé.

Connexion

Le champ d'en-tête général de connexion permet à l'expéditeur de spécifier les options souhaitées pour cette connexion particulière et ne doivent pas être communiquées par des mandataires sur d'autres connexions. Voici la syntaxe simple d'utilisation de l'en-tête de connexion:

Connection : "Connection"

HTTP / 1.1 définit l'option de connexion "fermée" pour que l'expéditeur signale que la connexion sera fermée une fois la réponse terminée. Par exemple:

Connection: Closed

Par défaut, HTTP 1.1 utilise des connexions persistantes, où la connexion ne se ferme pas automatiquement après une transaction. HTTP 1.0, en revanche, n'a pas de connexions persistantes par défaut. Si un client 1.0 souhaite utiliser des connexions persistantes, il utilise lekeep-alive paramètre comme suit:

Connection: keep-alive

Date

Tous les horodatages HTTP DOIVENT être représentés en heure moyenne de Greenwich (GMT), sans exception. Les applications HTTP sont autorisées à utiliser l'une des trois représentations suivantes des horodatages:

Sun, 06 Nov 1994 08:49:37 GMT  ; RFC 822, updated by RFC 1123
Sunday, 06-Nov-94 08:49:37 GMT ; RFC 850, obsoleted by RFC 1036
Sun Nov  6 08:49:37 1994       ; ANSI C's asctime() format

Ici, le premier format est le plus préféré.

Pragma

Le champ d'en-tête général Pragma est utilisé pour inclure des directives spécifiques à l'implémentation qui pourraient s'appliquer à n'importe quel destinataire le long de la chaîne de demande / réponse. Par exemple:

Pragma: no-cache

La seule directive définie dans HTTP / 1.0 est la directive no-cache et est maintenue dans HTTP 1.1 pour la compatibilité descendante. Aucune nouvelle directive Pragma ne sera définie à l'avenir.

Bande annonce

La valeur du champ général Trailer indique que l'ensemble donné de champs d'en-tête est présent dans la fin d'un message codé avec un codage de transfert fragmenté. Voici la syntaxe du champ d'en-tête Trailer:

Trailer : field-name

Les champs d'en-tête de message répertoriés dans le champ d'en-tête Trailer ne doivent pas inclure les champs d'en-tête suivants:

  • Transfer-Encoding

  • Content-Length

  • Trailer

Encodage de transfert

Le champ d'en-tête général Transfer-Encoding indique quel type de transformation a été appliqué au corps du message afin de le transférer en toute sécurité entre l'expéditeur et le destinataire. Ce n'est pas la même chose que le codage de contenu car les codages de transfert sont une propriété du message, pas du corps de l'entité. Voici la syntaxe du champ d'en-tête Transfer-Encoding:

Transfer-Encoding: chunked

Toutes les valeurs de codage de transfert sont insensibles à la casse.

Améliorer

L'en -tête général Upgrade permet au client de spécifier les protocoles de communication supplémentaires qu'il prend en charge et qu'il aimerait utiliser si le serveur juge approprié de changer de protocole. Par exemple:

Upgrade: HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11

Le champ d'en-tête Upgrade est destiné à fournir un mécanisme simple pour la transition de HTTP / 1.1 à un autre protocole incompatible

Via

L'en -tête général Via doit être utilisé par les passerelles et les mandataires pour indiquer les protocoles intermédiaires et les destinataires. Par exemple, un message de requête peut être envoyé d'un agent utilisateur HTTP / 1.0 à un proxy interne nommé "fred", qui utilise HTTP / 1.1 pour transmettre la requête à un proxy public sur nowhere.com, qui complète la requête en en le transmettant au serveur d'origine à l'adresse www.ics.uci.edu. La demande reçue par www.ics.uci.edu aurait alors le champ d'en-tête Via suivant:

Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)

Le champ d'en-tête Upgrade est destiné à fournir un mécanisme simple pour la transition de HTTP / 1.1 à un autre protocole incompatible

Attention

L'en -tête général Warning est utilisé pour transporter des informations supplémentaires sur l'état ou la transformation d'un message qui peuvent ne pas être reflétées dans le message. Une réponse peut porter plus d'un en-tête d'avertissement.

Warning : warn-code SP warn-agent SP warn-text SP warn-date

En-têtes de demande client

J'accepte

Le champ d'en-tête de demande Accepter peut être utilisé pour spécifier certains types de supports acceptables pour la réponse. Voici la syntaxe générale:

Accept: type/subtype [q=qvalue]

Plusieurs types de supports peuvent être répertoriés séparés par des virgules et la qvalue facultative représente un niveau de qualité acceptable pour les types d'acceptation sur une échelle de 0 à 1. Voici un exemple:

Accept: text/plain; q=0.5, text/html, text/x-dvi; q=0.8, text/x-c

Cela serait interprété comme text/html et text/x-c sont les types de médias préférés, mais s'ils n'existent pas, envoyez le text/x-dvi entité, et si cela n’existe pas, envoyez le text/plain entité.

Accepter-Charset

Le champ d'en-tête de demande Accept-Charset peut être utilisé pour indiquer quels jeux de caractères sont acceptables pour la réponse. Voici la syntaxe générale:

Accept-Charset: character_set [q=qvalue]

Plusieurs jeux de caractères peuvent être répertoriés séparés par des virgules et la qvalue facultative représente un niveau de qualité acceptable pour les jeux de caractères non préférés sur une échelle de 0 à 1. Voici un exemple:

Accept-Charset: iso-8859-5, unicode-1-1; q=0.8

La valeur spéciale "*", si présente dans le Accept-Charset champ, correspond à tous les jeux de caractères et si non Accept-Charset l'en-tête est présent, la valeur par défaut est que tout jeu de caractères est acceptable.

Accepter-encodage

Le champ d'en-tête de demande Accept-Encoding est similaire à Accept, mais restreint les codages de contenu qui sont acceptables dans la réponse. Voici la syntaxe générale:

Accept-Encoding: encoding types

Voici des exemples:

Accept-Encoding: compress, gzip
Accept-Encoding:
Accept-Encoding: *
Accept-Encoding: compress;q=0.5, gzip;q=1.0
Accept-Encoding: gzip;q=1.0, identity; q=0.5, *;q=0

Accept-Language

Le champ d'en-tête de demande Accept-Language est similaire à Accept, mais restreint l'ensemble des langages naturels qui sont préférés comme réponse à la demande. Voici la syntaxe générale:

Accept-Language: language [q=qvalue]

Plusieurs langues peuvent être répertoriées séparées par des virgules et la qvalue facultative représente un niveau de qualité acceptable pour les langues non préférées sur une échelle de 0 à 1. Voici un exemple:

Accept-Language: da, en-gb;q=0.8, en;q=0.7

Autorisation

La valeur du champ d'en-tête de demande d' autorisation se compose d'informations d'identification contenant les informations d'authentification de l'agent utilisateur pour le domaine de la ressource demandée. Voici la syntaxe générale:

Authorization : credentials

La spécification HTTP / 1.0 définit le schéma d'autorisation BASIC, où le paramètre d'autorisation est la chaîne de username:password encodé en base 64. Voici un exemple:

Authorization: BASIC Z3Vlc3Q6Z3Vlc3QxMjM=

La valeur se décode en est guest:guest123guest est l'ID utilisateur et guest123 est le mot de passe.

Biscuit

La valeur du champ d'en-tête de demande Cookie contient une paire nom / valeur d'informations stockées pour cette URL. Voici la syntaxe générale:

Cookie: name=value

Plusieurs cookies peuvent être spécifiés séparés par des points-virgules comme suit:

Cookie: name1=value1;name2=value2;name3=value3

Attendre

Le champ d'en-tête de demande Expect est utilisé pour indiquer que des comportements de serveur particuliers sont requis par le client. Voici la syntaxe générale:

Expect : 100-continue | expectation-extension

Si un serveur reçoit une demande contenant un champ Expect qui inclut une extension d'attente qu'il ne prend pas en charge, il doit répondre avec un état 417 (Expectation Failed).

De

Le champ d'en-tête de demande De contient une adresse de messagerie Internet pour l'utilisateur humain qui contrôle l'agent utilisateur demandeur. Voici un exemple simple:

From: [email protected]

Ce champ d'en-tête peut être utilisé à des fins de journalisation et comme moyen d'identifier la source de demandes invalides ou indésirables.

Hôte

Le champ d'en-tête de demande Host est utilisé pour spécifier l'hôte Internet et le numéro de port de la ressource demandée. Voici la syntaxe générale:

Host : "Host" ":" host [ ":" port ] ;

UNE hostsans aucune information de port de fin implique le port par défaut, qui est 80. Par exemple, une requête sur le serveur d'origine pour http://www.w3.org/pub/WWW/ serait:

GET /pub/WWW/ HTTP/1.1
Host: www.w3.org

Si-Match

Le champ d'en-tête de demande If-Match est utilisé avec une méthode pour le rendre conditionnel. Cet en-tête demande au serveur d'exécuter la méthode demandée uniquement si la valeur donnée dans cette balise correspond aux balises d'entité données représentées parETag. Voici la syntaxe générale:

If-Match : entity-tag

Un astérisque (*) correspond à n'importe quelle entité et la transaction se poursuit uniquement si l'entité existe. Voici des exemples possibles:

If-Match: "xyzzy"
If-Match: "xyzzy", "r2d2xxxx", "c3piozzzz"
If-Match: *

Si aucune des balises d'entité ne correspond, ou si "*" est donné et qu'aucune entité actuelle n'existe, le serveur ne doit pas exécuter la méthode demandée et doit renvoyer une réponse 412 (Échec de la condition préalable).

Si-modifié-depuis

Le champ d'en-tête de demande If-Modified-Since est utilisé avec une méthode pour le rendre conditionnel. Si l'URL demandée n'a pas été modifiée depuis l'heure spécifiée dans ce champ, une entité ne sera pas renvoyée par le serveur; à la place, une réponse 304 (non modifiée) sera retournée sans aucun corps de message. Voici la syntaxe générale:

If-Modified-Since : HTTP-date

Un exemple du champ est:

If-Modified-Since: Sat, 29 Oct 1994 19:43:31 GMT

Si aucune des balises d'entité ne correspond, ou si "*" est donné et qu'aucune entité actuelle n'existe, le serveur ne doit pas exécuter la méthode demandée et doit renvoyer une réponse 412 (Échec de la condition préalable).

Si-Aucun-Match

Le champ d'en-tête de demande If-None-Match est utilisé avec une méthode pour le rendre conditionnel. Cet en-tête demande au serveur d'exécuter la méthode demandée uniquement si l'une des valeurs données dans cette balise correspond aux balises d'entité données représentées parETag. Voici la syntaxe générale:

If-None-Match : entity-tag

Un astérisque (*) correspond à n'importe quelle entité et la transaction se poursuit uniquement si l'entité n'existe pas. Voici des exemples possibles:

If-None-Match: "xyzzy"
If-None-Match: "xyzzy", "r2d2xxxx", "c3piozzzz"
If-None-Match: *

If-Range

Le champ d'en-tête de demande If-Range peut être utilisé avec un GET conditionnel pour ne demander que la partie de l'entité qui manque, si elle n'a pas été modifiée, et l'entité entière si elle a changé. Voici la syntaxe générale:

If-Range : entity-tag | HTTP-date

Une balise d'entité ou une date peuvent être utilisées pour identifier l'entité partielle déjà reçue. Par exemple:

If-Range: Sat, 29 Oct 1994 19:43:31 GMT

Ici, si le document n'a pas été modifié depuis la date donnée, le serveur retourne la plage d'octets donnée par l'en-tête Range sinon, il retourne tout le nouveau document.

If-Unmodified-Since

Le champ d'en-tête de demande If-Unmodified-Since est utilisé avec une méthode pour le rendre conditionnel. Voici la syntaxe générale:

If-Unmodified-Since : HTTP-date

Si la ressource demandée n'a pas été modifiée depuis l'heure spécifiée dans ce champ, le serveur doit effectuer l'opération demandée comme si l'en-tête If-Unmodified-Since n'était pas présent. Par exemple:

If-Unmodified-Since: Sat, 29 Oct 1994 19:43:31 GMT

Si la demande aboutit normalement à autre chose qu'un état 2xx ou 412, l'en - tête If-Unmodified-Since doit être ignoré.

Max-avant

Le champ d'en-tête de demande Max-Forwards fournit un mécanisme avec les méthodes TRACE et OPTIONS pour limiter le nombre de mandataires ou de passerelles qui peuvent transmettre la demande au serveur entrant suivant. Voici la syntaxe générale:

Max-Forwards : n

La valeur Max-Forwards est un entier décimal indiquant le nombre de fois que ce message de demande peut être retransmis. Ceci est utile pour le débogage avec la méthode TRACE, en évitant les boucles infinies. Par exemple:

Max-Forwards : 5

Le champ d'en-tête Max-Forwards peut être ignoré pour toutes les autres méthodes définies dans la spécification HTTP.

Autorisation par procuration

Le champ d'en-tête de demande Proxy-Authorization permet au client de s'identifier (ou son utilisateur) auprès d'un proxy qui requiert une authentification. Voici la syntaxe générale:

Proxy-Authorization : credentials

La valeur du champ Proxy-Authorization se compose d'informations d'identification contenant les informations d'authentification de l'agent utilisateur pour le proxy et / ou le domaine de la ressource demandée.

Intervalle

Le champ d'en-tête de demande Range spécifie la ou les plages partielles du contenu demandé à partir du document. Voici la syntaxe générale:

Range: bytes-unit=first-byte-pos "-" [last-byte-pos]

La valeur first-byte-pos dans une spécification de plage d'octets donne le décalage d'octet du premier octet d'une plage. La valeur last-byte-pos donne le décalage d'octet du dernier octet de la plage; autrement dit, les positions d'octet spécifiées sont inclusives. Vous pouvez spécifier une unité d'octets car les décalages d'octets commencent à zéro. Voici quelques exemples simples:

- The first 500 bytes 
Range: bytes=0-499

- The second 500 bytes
Range: bytes=500-999

- The final 500 bytes
Range: bytes=-500

- The first and last bytes only
Range: bytes=0-0,-1

Plusieurs plages peuvent être répertoriées, séparées par des virgules. Si le premier chiffre de la ou des plages d'octets séparés par des virgules est manquant, la plage est supposée compter à partir de la fin du document. Si le deuxième chiffre est manquant, la plage va de l'octet n à la fin du document.

Référent

Le champ d'en-tête de demande Referer permet au client de spécifier l'adresse (URI) de la ressource à partir de laquelle l'URL a été demandée. Voici la syntaxe générale:

Referer : absoluteURI | relativeURI

Voici un exemple simple:

Referer: http://www.tutorialspoint.org/http/index.htm

Si la valeur du champ est un URI relatif, il doit être interprété par rapport à Request-URI .

TE

Le champ d'en-tête de demande TE indique quel codage de transfert d' extension il est prêt à accepter dans la réponse et s'il est prêt ou non à accepter des champs de fin dans un codage de transfert fragmenté . Voici la syntaxe générale:

TE   : t-codings

La présence du mot-clé "remorques" indique que le client est prêt à accepter les champs de fin dans un codage de transfert fragmenté et il est spécifié de l'une des manières suivantes:

TE: deflate
TE:
TE: trailers, deflate;q=0.5

Si la valeur de champ TE est vide ou si aucun champ TE n'est présent, le seul codage de transfert est fragmenté . Un message sans codage de transfert est toujours acceptable.

Agent utilisateur

Le champ d'en-tête de demande User-Agent contient des informations sur l'agent utilisateur à l'origine de la demande. Voici la syntaxe générale:

User-Agent : product | comment

Exemple:

User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)

En-têtes de réponse du serveur

Accepter les plages

Le champ d'en-tête de réponse Accept-Ranges permet au serveur d'indiquer son acceptation des demandes de plage pour une ressource. Voici la syntaxe générale:

Accept-Ranges  : range-unit | none

Par exemple, un serveur qui accepte les demandes de plage d'octets peut envoyer

Accept-Ranges: bytes

Les serveurs qui n'acceptent aucun type de demande de plage pour une ressource peuvent envoyer:

Accept-Ranges: none

Cela conseillera au client de ne pas tenter une demande de plage.

Âge

Le champ d'en-tête de réponse Age transmet l'estimation de l'expéditeur du temps écoulé depuis que la réponse (ou sa revalidation) a été générée sur le serveur d'origine. Voici la syntaxe générale:

Age : delta-seconds

Les valeurs d'âge sont des entiers décimaux non négatifs, représentant le temps en secondes. Voici un exemple simple:

Age: 1030

Un serveur HTTP / 1.1 qui inclut un cache doit inclure un champ d'en-tête Age dans chaque réponse générée à partir de son propre cache.

ETag

Le champ d'en -tête de réponse ETag fournit la valeur actuelle de l'étiquette d'entité pour la variante demandée. Voici la syntaxe générale:

ETag :  entity-tag

Voici des exemples simples:

ETag: "xyzzy"
ETag: W/"xyzzy"
ETag: ""

Emplacement

Le champ d'en-tête de réponse d' emplacement est utilisé pour rediriger le destinataire vers un emplacement autre que l'URI de demande pour exécution. Voici la syntaxe générale:

Location : absoluteURI

Voici un exemple simple:

Location: http://www.tutorialspoint.org/http/index.htm

Le champ d'en-tête Content-Location diffère de Location en ce que Content-Location identifie l'emplacement d'origine de l'entité incluse dans la demande.

Authentification proxy

Le champ d'en-tête de réponse Proxy-Authenticate doit être inclus dans le cadre d'une réponse 407 (Proxy Authentication Required). Voici la syntaxe générale:

Proxy-Authenticate  : challenge

Réessayer après

Le champ d'en-tête de réponse Retry-After peut être utilisé avec une réponse 503 (Service non disponible) pour indiquer combien de temps le service devrait être indisponible pour le client demandeur. Voici la syntaxe générale:

Retry-After : HTTP-date | delta-seconds

Voici deux exemples simples:

Retry-After: Fri, 31 Dec 1999 23:59:59 GMT
Retry-After: 120

Dans ce dernier exemple, le délai est de 2 minutes.

Serveur

Le champ d'en-tête de réponse du serveur contient des informations sur le logiciel utilisé par le serveur d'origine pour traiter la demande. Voici la syntaxe générale:

Server : product | comment

Voici un exemple simple:

Server: Apache/2.2.14 (Win32)

Si la réponse est transmise via un proxy, l'application proxy ne doit pas modifier l'en-tête de réponse du serveur.

Set-Cookie

Le champ d'en-tête de réponse Set-Cookie contient une paire nom / valeur d'informations à conserver pour cette URL. Voici la syntaxe générale:

Set-Cookie: NAME=VALUE; OPTIONS

L'en-tête de réponse Set-Cookie comprend le jeton Set-Cookie:, suivi d'une liste séparée par des virgules d'un ou plusieurs cookies. Voici les valeurs possibles que vous pouvez spécifier comme options:

SN Options et description
1 Comment=comment
Cette option peut être utilisée pour spécifier tout commentaire associé au cookie.
2 Domain=domain
L'attribut Domaine spécifie le domaine pour lequel le cookie est valide.
3 Expires=Date-time
La date d'expiration du cookie. Si ce champ est vide, le cookie expirera lorsque le visiteur quittera le navigateur
4 Path=path
L'attribut Path spécifie le sous-ensemble d'URL auquel ce cookie s'applique.
5 Secure
Cela indique à l'agent utilisateur de ne renvoyer le cookie que sous une connexion sécurisée.

Voici un exemple d'en-tête de cookie simple généré par le serveur:

Set-Cookie: name1=value1,name2=value2; Expires=Wed, 09 Jun 2021 10:18:14 GMT

Varier

Le champ d'en-tête de réponse Vary spécifie que l'entité a plusieurs sources et peut donc varier selon la liste spécifiée d'en-tête (s) de demande. Voici la syntaxe générale:

Vary : field-name

Vous pouvez spécifier plusieurs en-têtes séparés par des virgules et une valeur d'astérisque "*" signale que des paramètres non spécifiés ne sont pas limités aux en-têtes de demande. Voici un exemple simple:

Vary: Accept-Language, Accept-Encoding

Ici, les noms de champ ne sont pas sensibles à la casse.

Authentification WWW

Le champ d'en-tête de réponse WWW-Authenticate doit être inclus dans les messages de réponse 401 (non autorisés). La valeur du champ se compose d'au moins un défi qui indique le ou les schémas d'authentification et les paramètres applicables à l'URI de demande. Voici la syntaxe générale:

WWW-Authenticate : challenge

Valeur du champ WWW-Authenticate car elle peut contenir plus d'un défi, ou si plusieurs champs d'en-tête WWW-Authenticate sont fournis, le contenu d'un défi lui-même peut contenir une liste de paramètres d'authentification séparés par des virgules. Voici un exemple simple:

WWW-Authenticate: BASIC realm="Admin"

En-têtes d'entité

Autoriser

Le champ d'en-tête de l'entité Autoriser répertorie l'ensemble des méthodes prises en charge par la ressource identifiée par l'URI de demande. Voici la syntaxe générale:

Allow : Method

Vous pouvez spécifier plusieurs méthodes séparées par des virgules. Voici un exemple simple:

Allow: GET, HEAD, PUT

Ce champ ne peut pas empêcher un client d'essayer d'autres méthodes.

Encodage de contenu

Le champ d'en-tête d'entité Content-Encoding est utilisé comme modificateur du type de média. Voici la syntaxe générale:

Content-Encoding : content-coding

Le codage de contenu est une caractéristique de l'entité identifiée par l'URI de demande. Voici un exemple simple:

Content-Encoding: gzip

Si le codage de contenu d'une entité dans un message de demande n'est pas acceptable pour le serveur d'origine, le serveur doit répondre avec un code d'état 415 (type de support non pris en charge).

Contenu-Langue

Le champ d'en-tête d'entité Content-Language décrit le (s) langage (s) naturel (s) du public visé pour l'entité incluse. Voici la syntaxe générale:

Content-Language : language-tag

Plusieurs langues peuvent être répertoriées pour le contenu destiné à plusieurs publics. Voici un exemple simple:

Content-Language: mi, en

L'objectif principal de Content-Language est de permettre à un utilisateur d'identifier et de différencier les entités en fonction de la langue préférée de l'utilisateur.

Content-Length

Le champ d'en-tête d'entité Content-Length indique la taille du corps d'entité, en nombre décimal d'OCTET, envoyé au destinataire ou, dans le cas de la méthode HEAD, la taille du corps d'entité qui aurait été envoyé avait la demande était un GET. Voici la syntaxe générale:

Content-Length : DIGITS

Voici un exemple simple:

Content-Length: 3495

Tout Content-Length supérieur ou égal à zéro est une valeur valide.

Emplacement du contenu

Le champ d'en-tête d'entité Content-Location peut être utilisé pour fournir l'emplacement de ressource pour l'entité incluse dans le message lorsque cette entité est accessible à partir d'un emplacement distinct de l'URI de la ressource demandée. Voici la syntaxe générale:

Content-Location:  absoluteURI | relativeURI

Voici un exemple simple:

Content-Location: http://www.tutorialspoint.org/http/index.htm

La valeur de Content-Location définit également l'URI de base de l'entité.

Contenu-MD5

Le champ d'en-tête d'entité Content-MD5 peut être utilisé pour fournir un condensé MD5 de l'entité, pour vérifier l'intégrité du message à la réception. Voici la syntaxe générale:

Content-MD5  : md5-digest using base64 of 128 bit MD5 digest as per RFC 1864

Voici un exemple simple:

Content-MD5  : 8c2d46911f3f5a326455f0ed7a8ed3b3

Le résumé MD5 est calculé sur la base du contenu du corps d'entité, y compris tout codage de contenu qui a été appliqué, mais sans inclure tout codage de transfert appliqué au corps du message.

Gamme de contenu

Le champ d'en-tête d'entité Content-Range est envoyé avec un corps d'entité partiel pour spécifier où dans le corps d'entité complet le corps partiel doit être appliqué. Voici la syntaxe générale:

Content-Range : bytes-unit SP first-byte-pos "-" last-byte-pos

Exemples de valeurs byte-content-range-spec, en supposant que l'entité contient un total de 1234 octets:

- The first 500 bytes:
Content-Range : bytes 0-499/1234

- The second 500 bytes:
Content-Range : bytes 500-999/1234

- All except for the first 500 bytes:
Content-Range : bytes 500-1233/1234

- The last 500 bytes:
Content-Range : bytes 734-1233/1234

Lorsqu'un message HTTP inclut le contenu d'une seule plage, ce contenu est transmis avec un en-tête Content-Range et un en-tête Content-Length indiquant le nombre d'octets réellement transférés. Par exemple,

HTTP/1.1 206 Partial content
Date: Wed, 15 Nov 1995 06:25:24 GMT
Last-Modified: Wed, 15 Nov 1995 04:58:08 GMT
Content-Range: bytes 21010-47021/47022
Content-Length: 26012
Content-Type: image/gif

Type de contenu

Le champ d'en-tête d'entité Content-Type indique le type de média du corps d'entité envoyé au destinataire ou, dans le cas de la méthode HEAD, le type de média qui aurait été envoyé si la demande avait été un GET. Voici la syntaxe générale:

Content-Type : media-type

Voici un exemple:

Content-Type: text/html; charset=ISO-8859-4

Expire

Le Expires champ en -tête de l' entité donne la date / heure , après quoi la réponse est considérée comme obsolète. Voici la syntaxe générale:

Expires : HTTP-date

Voici un exemple:

Expires: Thu, 01 Dec 1994 16:00:00 GMT

Dernière modification

Le champ d'en-tête d'entité Last-Modified indique la date et l'heure auxquelles le serveur d'origine pense que la variante a été modifiée pour la dernière fois. Voici la syntaxe générale:

Last-Modified: HTTP-date

Voici un exemple:

Last-Modified: Tue, 15 Nov 1994 12:45:26 GMT

HTTP est généralement utilisé pour les systèmes d'information distribués, où les performances peuvent être améliorées par l'utilisation de caches de réponse. Le protocole HTTP / 1.1 comprend un certain nombre d'éléments destinés à faire fonctionner la mise en cache.

L'objectif de la mise en cache dans HTTP / 1.1 est d'éliminer le besoin d'envoyer des requêtes dans de nombreux cas, et d'éliminer le besoin d'envoyer des réponses complètes dans de nombreux autres cas.

Les mécanismes de cache de base dans HTTP / 1.1 sont des directives implicites vers les caches où le serveur spécifie les délais d'expiration et les validateurs. Nous utilisons leCache-Control en-tête à cet effet.

le Cache-ControlL'en-tête permet à un client ou serveur de transmettre une variété de directives dans les requêtes ou les réponses. Ces directives remplacent généralement les algorithmes de mise en cache par défaut. Les directives de mise en cache sont spécifiées dans une liste séparée par des virgules. Par exemple:

Cache-control: no-cache

Les directives de requête de cache importantes suivantes peuvent être utilisées par le client dans sa requête HTTP:

SN Directive et description de la demande de cache
1 no-cache
Un cache ne doit pas utiliser la réponse pour satisfaire une demande ultérieure sans une revalidation réussie avec le serveur d'origine.
2 no-store
Le cache ne doit rien stocker sur la demande du client ou la réponse du serveur.
3 max-age = seconds
Indique que le client est prêt à accepter une réponse dont l'âge n'est pas supérieur au temps spécifié en secondes.
4 max-stale [ = seconds ]
Indique que le client est prêt à accepter une réponse qui a dépassé son délai d'expiration. Si des secondes sont données, elles ne doivent pas être expirées de plus de ce temps.
5 min-fresh = seconds
Indique que le client est prêt à accepter une réponse dont la durée de vie d'actualisation n'est pas inférieure à son âge actuel plus la durée spécifiée en secondes.
6 no-transform
Ne convertissez pas le corps de l'entité.
sept only-if-cached
Ne récupérez pas de nouvelles données. Le cache peut envoyer un document uniquement s'il se trouve dans le cache et ne doit pas contacter le serveur d'origine pour voir si une copie plus récente existe.

Les directives de réponse de cache importantes suivantes peuvent être utilisées par le serveur dans sa réponse HTTP:

SN Directive et description de la réponse du cache
1 public
Indique que la réponse peut être mise en cache par n'importe quel cache.
2 private
Indique que tout ou partie du message de réponse est destiné à un seul utilisateur et ne doit pas être mis en cache par un cache partagé.
3 no-cache
Un cache ne doit pas utiliser la réponse pour satisfaire une demande ultérieure sans une revalidation réussie avec le serveur d'origine.
4 no-store
Le cache ne doit rien stocker sur la demande du client ou la réponse du serveur.
5 no-transform
Ne convertissez pas le corps de l'entité.
6 must-revalidate
Le cache doit vérifier l'état des documents périmés avant de l'utiliser et un document périmé ne doit pas être utilisé.
sept proxy-revalidate
La directive proxy-revalidate a la même signification que la directive must-revalidate, sauf qu'elle ne s'applique pas aux caches d'agent utilisateur non partagés.
8 max-age = seconds
Indique que le client est prêt à accepter une réponse dont l'âge n'est pas supérieur au temps spécifié en secondes.
9 s-maxage = seconds
L'âge maximum spécifié par cette directive remplace l'âge maximum spécifié par la directive max-age ou par l'en-tête Expires. La directive s-maxage est toujours ignorée par un cache privé.

Les URL HTTP ne peuvent être envoyées sur Internet qu'en utilisant le jeu de caractères ASCII , qui contient souvent des caractères en dehors du jeu ASCII. Donc, ces caractères dangereux doivent être remplacés par un% suivi de deux chiffres hexadécimaux.

Le tableau suivant montre le symbole ASCII du caractère et son symbole égal et enfin son remplacement qui peut être utilisé dans l'URL avant de le transmettre au serveur:

ASCII symbole Remplacement
<32   Encode avec% xx où xx est la représentation hexadécimale du caractère.
32 espace + ou% 20
33 ! % 21
34 " % 22
35 # % 23
36 $ % 24
37 % % 25
38 & % 26
39 ' % 27
40 ( % 28
41 ) % 29
42 * *
43 + % 2B
44 , % 2C
45 - -
46 . .
47 / % 2F
48 0 0
49 1 1
50 2 2
51 3 3
52 4 4
53 5 5
54 6 6
55 sept sept
56 8 8
57 9 9
58 : % 3A
59 ; % 3B
60 < % 3C
61 = % 3D
62 > % 3E
63 ? % 3F
64 @ % 40
65 UNE UNE
66 B B
67 C C
68
69 E E
70 F F
71 g g
72 H H
73 je je
74 J J
75 K K
76 L L
77 M M
78 N N
79 O O
80 P P
81 Q Q
82 R R
83 S S
84 T T
85 U U
86 V V
87 W W
88 X X
89 Oui Oui
90 Z Z
91 [ % 5B
92 \ % 5C
93 ] % 5D
94 ^ % 5E
95 _ _
96 » % 60
97 une une
98 b b
99 c c
100
101 e e
102 F F
103 g g
104 h h
105 je je
106 j j
107 k k
108 l l
109 m m
110 n n
111 o o
112 p p
113 q q
114 r r
115 s s
116 t t
117 u u
118 v v
119 w w
120 X X
121 y y
122 z z
123 { % 7B
124 | % 7C
125 } % 7D
126 ~ % 7E
127   % 7F
> 127   Encode avec% xx où xx est la représentation hexadécimale du caractère

HTTP est utilisé pour une communication sur Internet, les développeurs d'applications, les fournisseurs d'informations et les utilisateurs doivent donc être conscients des limites de sécurité de HTTP / 1.1. Cette discussion n'inclut pas de solutions définitives aux problèmes mentionnés ici, mais fait quelques suggestions pour réduire les risques de sécurité.

Fuite d'informations personnelles

Les clients HTTP ont souvent accès à de grandes quantités d'informations personnelles telles que le nom de l'utilisateur, l'emplacement, l'adresse mail, les mots de passe, les clés de cryptage, etc. Vous devez donc être très prudent pour éviter toute fuite involontaire de ces informations via le protocole HTTP vers d'autres sources.

  • Toutes les informations confidentielles doivent être stockées côté serveur sous forme cryptée.

  • La révélation de la version logicielle spécifique du serveur peut permettre à la machine serveur de devenir plus vulnérable aux attaques contre des logiciels connus pour contenir des failles de sécurité.

  • Les proxys qui servent de portail via un pare-feu réseau doivent prendre des précautions particulières concernant le transfert des informations d'en-tête qui identifient les hôtes derrière le pare-feu.

  • Les informations envoyées dans le champ De peuvent entrer en conflit avec les intérêts de confidentialité de l'utilisateur ou la politique de sécurité de leur site, et par conséquent, elles ne doivent pas être transmises sans que l'utilisateur puisse désactiver, activer et modifier le contenu du champ.

  • Les clients ne doivent pas inclure de champ d'en-tête Referer dans une requête HTTP (non sécurisée) si la page de référence a été transférée avec un protocole sécurisé.

  • Les auteurs de services qui utilisent le protocole HTTP ne doivent pas utiliser de formulaires basés sur GET pour la soumission de données sensibles, car cela entraînera l'encodage de ces données dans Request-URI

Attaque basée sur les noms de fichiers et de chemins

Le document doit être limité aux documents renvoyés par les requêtes HTTP pour être uniquement ceux qui ont été voulus par les administrateurs du serveur.

Par exemple, UNIX, Microsoft Windows et d'autres systèmes d'exploitation utilisent ..comme composant de chemin pour indiquer un niveau de répertoire au-dessus du niveau actuel. Sur un tel système, un serveur HTTP DOIT interdire une telle construction dans l'URI-de-demande s'il autorise autrement l'accès à une ressource en dehors de celles destinées à être accessibles via le serveur HTTP.

Usurpation DNS

Les clients utilisant HTTP dépendent fortement du service de noms de domaine et sont donc généralement sujets à des attaques de sécurité basées sur une mauvaise association délibérée d'adresses IP et de noms DNS. Les clients doivent donc être prudents lorsqu'ils supposent la validité continue d'une association numéro IP / nom DNS.

Si les clients HTTP mettent en cache les résultats des recherches de nom d'hôte afin d'améliorer les performances, ils doivent observer les informations TTL rapportées par DNS. Si les clients HTTP ne respectent pas cette règle, ils peuvent être usurpés lorsque l'adresse IP d'un serveur précédemment accédé change.

En-têtes d'emplacement et usurpation d'identité

Si un seul serveur prend en charge plusieurs organisations qui ne se font pas confiance, il DOIT alors vérifier les valeurs des en-têtes Location et Content-Location dans les réponses générées sous le contrôle desdites organisations pour s'assurer qu'elles n'essaient pas d'invalider les ressources sur lesquelles ils n'ont aucune autorité.

Identifiants d'authentification

Les clients HTTP et les agents utilisateurs existants conservent généralement les informations d'authentification indéfiniment. HTTP / 1.1. ne fournit pas de méthode permettant à un serveur de demander aux clients de supprimer ces informations d'identification mises en cache, ce qui représente un risque majeur pour la sécurité.

Il existe un certain nombre de solutions de contournement à certaines parties de ce problème, et il est donc recommandé d'utiliser la protection par mot de passe dans les économiseurs d'écran, les délais d'inactivité et d'autres méthodes qui atténuent les problèmes de sécurité inhérents à ce problème.

Proxies et mise en cache

Les proxies HTTP sont des hommes du milieu et représentent une opportunité pour les attaques de type "man-in-the-middle". Les mandataires ont accès aux informations relatives à la sécurité, aux informations personnelles sur les utilisateurs individuels et les organisations, et aux informations exclusives appartenant aux utilisateurs et aux fournisseurs de contenu.

Les opérateurs proxy doivent protéger les systèmes sur lesquels les proxy fonctionnent comme ils protégeraient tout système contenant ou transportant des informations sensibles.

Les proxies de mise en cache fournissent des vulnérabilités potentielles supplémentaires, car le contenu du cache représente une cible attrayante pour l'exploitation malveillante. Par conséquent, le contenu du cache doit être protégé en tant qu'informations sensibles.

Exemple 1

Requête HTTP à récupérer hello.htmpage du serveur Web s'exécutant sur tutorialspoint.com

Demande du client

GET /hello.htm HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Réponse du serveur

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
Content-Length: 88
Content-Type: text/html
Connection: Closed

<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>

Exemple 2

Requête HTTP à récupérer t.htmlpage qui n'existe pas sur le serveur Web fonctionnant sur tutorialspoint.com

Demande du client

GET /t.html HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Réponse du serveur

HTTP/1.1 404 Not Found
Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Content-Type: text/html; charset=iso-8859-1
Connection: close
   
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head>
   <title>404 Not Found</title>
</head>
<body>
   <h1>Not Found</h1>
   <p>The requested URL /t.html was not found on this server.</p>
</body>
</html>

Exemple 3

Requête HTTP à récupérer hello.htmpage du serveur Web en cours d'exécution sur tutorialspoint.com , mais la requête est associée à une mauvaise version HTTP:

Demande du client

GET /hello.htm HTTP1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Réponse du serveur

HTTP/1.1 400 Bad Request
Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Content-Type: text/html; charset=iso-8859-1
Connection: close
   
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head>
   <title>400 Bad Request</title>
</head>
<body>
   <h1>Bad Request</h1>
   <p>Your browser sent a request that this server could not understand.<p>
   <p>The request line contained invalid characters following the protocol string.<p>
</body>
</html>

Exemple 4

Requête HTTP pour publier des données de formulaire sur process.cgiPage CGI sur un serveur Web fonctionnant sur tutorialspoint.com . Le serveur renvoie le nom passé après les avoir définis comme cookies:

Demande du client

POST /cgi-bin/process.cgi HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Content-Type: text/xml; charset=utf-8
Content-Length: 60
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

first=Zara&last=Ali

Réponse du serveur

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 88
Set-Cookie: first=Zara,last=Ali;domain=tutorialspoint.com;Expires=Mon, 19-
Nov-2010 04:38:14 GMT;Path=/
Content-Type: text/html
Connection: Closed

<html>
<body>
<h1>Hello Zara Ali</h1>
</body>
</html>