Maison  >  Article  >  interface Web  >  Présentation détaillée du serveur Web

Présentation détaillée du serveur Web

PHP中文网
PHP中文网original
2017-06-21 10:58:281751parcourir

1. Introduction au protocole HTTP

HTTP est l'abréviation de Hyper Text Transfer Protocol. Son développement est le résultat de la coopération entre le World Wide Web Consortium et l'Internet Engineering Task Force (IETF), qui ont finalement publié une série de RFC (RFC 1945) définissant la version HTTP/1.0. La plus connue d’entre elles est la RFC 2616. La RFC 2616 définit une version couramment utilisée aujourd'hui : HTTP 1.1.

Le protocole HTTP (HyperText Transfer Protocol, Hypertext Transfer Protocol) est un protocole de transfert utilisé pour transférer l'hypertexte du serveur WWW vers le navigateur local. Cela peut rendre le navigateur plus efficace et réduire la transmission réseau. Il garantit non seulement que l'ordinateur transmet correctement et rapidement les documents hypertextes, mais détermine également quelle partie du document est transmise et quelle partie du contenu est affichée en premier (comme le texte avant les graphiques), etc.

  • HTTP est un protocole de communication basé sur TCP/IP pour transférer des données (fichiers HTML, fichiers images, résultats de requêtes, etc.).

  • HTTP est un protocole de couche application, composé de requêtes et de réponses, et est un modèle client-serveur standard.

  • HTTP est un protocole sans état.

 ![Échec du téléchargement de la compréhension approfondie du protocole HTTP.jpg Veuillez réessayer.]


Le protocole HTTP est toujours le client. Lancez une requête et le serveur renvoie une réponse.


Cela limite l'utilisation du protocole HTTP, et il est impossible pour le serveur de transmettre des messages au client lorsque celui-ci n'initie pas de requête.
Le protocole HTTP est un protocole sans état. Il n'y a aucune correspondance entre cette requête et la dernière requête du même client.

2.Analyse du protocole http

1. Requête du navigateur


Méthode de requête http


On peut correspondre aux opérations CRUD d'ajout, de suppression, de modification et de requête de la base de données :

  1. CREATE : PUT

  2. LECTURE : GET

  3. MISE À JOUR : POST

  4. DELETE : DELETE

Réponse du serveur

Points de réponse HTTP Pour les deux parties : Header et Body (Body est facultatif), les lignes les plus importantes du Header que nous voyons dans le réseau sont les suivantes :
HTTP/1.1 200 OK
200 indique une réponse réussie , et le OK suivant est illustré.
Si la valeur renvoyée n'est pas 200, il existe souvent d'autres fonctions, telles que

  • La réponse échouée est 404 Not Found : la page Web n'existe pas

  • 500 Erreur interne du serveur : Erreur interne du serveur

  • ...etc...


Code d'état HTTP.jpg


Content-Type : text/html
Content-Type indique le contenu de la réponse, ici text/html représente une page Web HTML.

3. Processus d'analyse du navigateur

Lorsque le navigateur lit le code source HTML de la page d'accueil de Sina, il analysera le HTML, affichera la page, puis, en fonction des différents liens contenus dans le HTML. , Envoyez une requête HTTP au serveur Sina, obtenez les images, vidéos, Flash, scripts JavaScript, CSS et autres ressources correspondants, et enfin affichez une page complète.

3. Résumé

1. Processus de requête HTTP

En suivant la page d'accueil de Sina, résumons le processus de requête HTTP :

Étape 1 : Le navigateur envoie d'abord une requête HTTP au serveur. La requête comprend :

Méthode : GET ou POST, GET demande uniquement des ressources, POST sera accompagné des données utilisateur ; > Nom de domaine : spécifié par l'en-tête de l'hôte : Hôte : www.sina.com
et autres en-têtes associés
S'il s'agit d'un POST, la demande comprend également un corps, y compris les données utilisateur

Étape ; 2 : Serveur Renvoie une réponse HTTP au navigateur. La réponse comprend :

Code de réponse : 200 signifie succès, 3xx signifie redirection, 4xx signifie qu'il y a une erreur dans la requête envoyée par le client et 5xx signifie une une erreur s'est produite lors du traitement côté serveur ;
Type de réponse : spécifié par Content-Type ;

et autres en-têtes associés
Habituellement, la réponse HTTP du serveur contient du contenu, c'est-à-dire qu'il existe un corps contenant le le contenu de la réponse et le code source HTML de la page Web se trouve dans le Body .

Étape 3 : Si le navigateur doit continuer à demander d'autres ressources au serveur, telles que des images, effectuez une autre requête HTTP et répétez les étapes 1 et 2.

Le protocole HTTP adopté par le Web adopte un modèle requête-réponse très simple, ce qui simplifie grandement le développement. Lorsque nous écrivons une page, il nous suffit d'envoyer le HTML dans la requête HTTP, et nous n'avons pas besoin de réfléchir à la manière de joindre des images, des vidéos, etc. Si le navigateur a besoin de demander des images et des vidéos, il enverra une autre requête HTTP. Par conséquent, une requête HTTP ne traite qu'une seule ressource (cela peut être compris comme une connexion courte dans le protocole TCP. Chaque lien n'obtient qu'une seule ressource. Si vous en avez besoin de plus, vous devez établir plusieurs liens)
Le protocole HTTP également a une forte évolutivité , bien que le navigateur demande la page d'accueil, Sina peut lier des ressources d'autres serveurs en HTML, comme ![](http://upload-images.jianshu.io/upload_images/6078268-6060a9b222ef1412.png?imageMogr2/ auto -orient/strip%7CimageView2/2/w/1240), dispersant ainsi la pression des requêtes sur différents serveurs, et un site peut être lié à d'autres sites, et d'innombrables sites sont liés les uns aux autres pour former le World Wide Web, appelé comme WWW.


Format 2.HTTP

Informations de demande du client
Message de réponse du serveur
    Chaque requête et réponse HTTP suit le même format. Un HTTP contient deux parties : l'en-tête et le corps, dont le corps est facultatif.
  • Le protocole HTTP est un protocole texte, son format est donc également très simple.
  • Format de requête HTTP GET :

    GET /path HTTP/1.1
    En-tête1 : Valeur1
    En-tête2 : Valeur2
    En-tête3 : Valeur3
    Chaque en-tête est une ligne et le caractère de nouvelle ligne est rn ou Le format de la requête HTTP POST avec os.linesep
     :
    POST /path HTTP/1.1
    Header1 : Value1
    Header2 : Value2
    Header3 : Value3

    body data va ici...

    Lorsque deux rn consécutifs sont rencontrés, la partie en-tête se termine et toutes les données suivantes sont le corps.

    Format de réponse HTTP :
    200 OK
    En-tête1 : Valeur1
    En-tête2 : Valeur2
    En-tête3 : Valeur3

    les données du corps vont ici...

    Réponse HTTP si incluse corps, également séparé par rnrn.

    Veuillez noter encore une fois que le type de données du Body est déterminé par l'en-tête Content-Type. S'il s'agit d'une page Web, le Body est du texte. S'il s'agit d'une image, le Body est les données binaires de l'image.
    Lorsque Content-Encoding existe, les données Body sont compressées. La méthode de compression la plus courante est gzip. Par conséquent, lorsque vous voyez Content-Encoding : gzip, vous devez d'abord décompresser les données Body pour obtenir les données réelles. Le but de la compression est de réduire la taille du corps et d'accélérer la transmission sur le réseau.

    4Serveur statique Web

    1. Afficher la page fixe

import socketimport multiprocessingimport osimport timedef serverHandler(clientSocket, clientAddr):'与请求的客户端进行交互'# 接收客户端发来的消息
    recvData = clientSocket.recv(1024).decode('utf-8')
    print(recvData)# 服务端向客户端发消息,作为响应
    responseLine = 'HTTP/1.1 200 OK' + os.linesep
    responseHeader = 'Server: laowang' + os.linesep
    responseHeader += 'Date: %s' % time.ctime() + os.linesep
    responseBody = '差一点一米八'
    sendData = (responseLine + responseHeader + os.linesep + responseBody).encode('gbk')

    clientSocket.send(sendData)# 关闭
    clientSocket.close()def main():'程序入口'# socket对象
    serverSocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 绑定的端口号,可以重复使用端口号#serverSocket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)# 绑定
    serverSocket.bind(('', 8000))# 监听
    serverSocket.listen()while True:# 接收
        clientSocket, clientAddr = serverSocket.accept()
        print(clientSocket)# 开一个新的进程,执行交互
        multiprocessing.Process(target=serverHandler, args=(clientSocket, clientAddr)).start()# 关闭客户端对象
        clientSocket.close()if __name__ == '__main__':
    main()
Page du navigateur client
2. Afficher la page requise

import time,multiprocessing,socket,os,re

G_PATH = './html'

def serveHandler(clientSocket,clientAddr):
    recvData = clientSocket.recv(1024).decode('gbk')
    lineFirst = recvData.splitlines()[0]
    strFirst = re.split(r' +',lineFirst)
    fileName = strFirst[1]

    filePath = G_PATHif '/'== fileName:
        filePath += './index.html'else:
        filePath += fileNametry:file = Nonefile =open(filePath,'r',encoding='gbk')
        responseBody = file.read()

        responseLine = 'HTTP/1.1 200 OK' + os.linesep
        responseHeader = 'Server: ererbai' + os.linesep
        responseHeader += 'Date:%s' % time.ctime() + os.linesep
    except FileNotFoundError:
        responseLine = 'HTTP/1.1 404 NOT FOUND' + os.linesep
        responseHeader = 'Server: ererbai' + os.linesep
        responseHeader += 'Date:%s' % time.ctime() + os.linesep
        responseBody = '很抱歉,服务器中找不到你想要的内容'
    except Exception:
        responseLine = 'HTTP/1.1 500 ERROR' + os.linesep
        responseHeader = 'Server: ererbai' + os.linesep
        responseHeader += 'Date: %s' % time.ctime() + os.linesep
        responseBody = '服务器正在维护中,请稍后再试。'finally:if file!=None and not file.closed:file.close()

        senData = (responseLine + responseHeader + os.linesep + responseBody).encode('gbk')
        clientSocket.send(senData)
        clientSocket.close()


def main():
    serveSocket=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
    serveSocket.bind(('',8000))
    serveSocket.listen()while True:
        clientSocket,clientAddr = serveSocket.accept()
        print(clientSocket)
        multiprocessing.Process(target=serveHandler,args=(clientSocket,clientAddr)).start()
        clientSocket.close()if __name__ == '__main__':
    main()
Page d'accueil du navigateur client
Page biye.html du navigateur client


Si vous rencontrez des problèmes pendant le processus d'apprentissage ou si vous souhaitez obtenir des ressources d'apprentissage, vous êtes invités à rejoindre le groupe d'échange d'apprentissage
343599877, apprenons ensemble le front-end !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn