HTTP - Présentation
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 des extensions 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 également ê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épondent à ces demandes.
Caractéristiques de base
Il existe trois fonctionnalités de base qui font de HTTP un protocole simple mais puissant:
HTTP is connectionless:Le client HTTP, c'est-à-dire un navigateur, lance une requête HTTP et après qu'une requête est faite, le client attend la réponse. Le serveur traite la demande et renvoie une réponse après quoi le client déconnecte la connexion. Ainsi, le client et le serveur se connaissent uniquement lors de la demande et de la réponse en cours. D'autres demandes sont faites sur une nouvelle connexion comme le client et le serveur sont nouveaux l'un pour l'autre.
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. Il est nécessaire que le client ainsi que le serveur spécifient le type de contenu à l'aide du type MIME approprié.
HTTP is stateless:Comme mentionné ci-dessus, HTTP est sans connexion et c'est le résultat direct du fait 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 demandes sur les pages Web.
HTTP / 1.0 utilise une nouvelle connexion pour chaque échange de demande / réponse, où 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 illustre l'emplacement de HTTP:
Le protocole HTTP est un protocole de requête / réponse basé sur l'architecture client / serveur où les navigateurs 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, y compris 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é.