目錄
1.HTTP協定介紹
2.http協定分析
1.瀏覽器請求
3.瀏覽器解析過程
3.總​​結
1.HTTP請求流程
步驟1:瀏覽器先向伺服器傳送HTTP請求,請求包含:
步驟2:伺服器向瀏覽器返回HTTP回應,回應包括:
步驟3:如果瀏覽器還需要繼續向伺服器請求其他資源,例如圖片,就再次發出HTTP請求,重複步驟1、2。
2.HTTP格式
首頁 web前端 html教學 web伺服器的具體介紹

web伺服器的具體介紹

Jun 21, 2017 am 10:58 AM
web 伺服器

1.HTTP協定介紹

HTTP是Hyper Text Transfer Protocol(超文本傳輸協定)的縮寫。它的發展是萬維網協會(World Wide Web Consortium)和Internet工作小組IETF(Internet Engineering Task Force)合作的結果,(他們)最終發布了一系列的RFC,RFC 1945定義了HTTP/1.0版本。其中最著名的就是RFC 2616。 RFC 2616定義了今天普遍使用的一個版本-HTTP 1.1。

HTTP協定(HyperText Transfer Protocol,超文本傳輸協定)是用於從WWW伺服器傳輸超文本到本機瀏覽器的傳送協定。它可以使瀏覽器更加高效,使網路傳輸減少。它不僅保證電腦正確快速地傳輸超文本文檔,還確定傳輸文檔中的哪一部分,以及哪部分內容首先顯示(如文本先於圖形)等。

  • HTTP是基於TCP/IP通訊協定來傳遞資料(HTML 檔案, 圖片檔案, 查詢結果等)。

  • HTTP是一個應用層協議,由請求和回應構成,是一個標準的客戶端伺服器模型。

  • HTTP是一個無狀態的協定。

![Upload 深入理解HTTP協定.jpg failed. Please try again.]


HTTP協定永遠都是客戶端發起請求,伺服器回傳回應。


這樣就限制了使用HTTP協議,無法實現在客戶端沒有發起請求的時候,伺服器將訊息推送給客戶端。
HTTP協定是一個無狀態的協議,同一個客戶端的這次請求和上次請求是沒有對應關係。

2.http協定分析

1.瀏覽器請求


#http請求方法


我們可以跟資料庫的CRUD增刪改查作業對應起來:

  1. CREATE :PUT

  2. ##READ:GET





##UPDATE:POST
#########DELETE:DELETE############2.伺服器回應######HTTP回應分為Header和Body兩部分(Body是可選項),我們在Network中看到的Header最重要的幾行如下:###HTTP/1.1 200 OK###200表示一個成功的回應,後面的OK是說明。 ###如果回傳的不是200,那麼往往有其他的功能,例如############失敗的回應有404 Not Found:網頁不存在########## ##500 Internal Server Error:伺服器內部出錯############...等等...########################### #HTTP狀態碼.jpg#######


Content-Type: text/html
Content-Type指示回應的內容,這裡是text/html表示HTML網頁。

3.瀏覽器解析過程

當瀏覽器讀取到新浪首頁的HTML源碼後,它會解析HTML,顯示頁面,然後,根據HTML裡面的各種鏈接,再發送HTTP請求給新浪伺服器,拿到對應的圖片、影片、Flash、JavaScript腳本、CSS等各種資源,最後顯示出完整的頁面。

3.總​​結

1.HTTP請求流程

追蹤了新浪的首頁,我們來總結一下HTTP請求的流程:

步驟1:瀏覽器先向伺服器傳送HTTP請求,請求包含:

方法:GET或POST,GET只要求資源,POST會附帶使用者資料;
路徑:/full/url/path;
網域:由Host頭指定:Host: www.sina.com
以及其他相關的Header;
如果是POST,那麼請求還包括一個Body,包含用戶資料

步驟2:伺服器向瀏覽器返回HTTP回應,回應包括:

回應代碼:200表示成功,3xx表示重定向,4xx表示客戶端發送的請求有錯誤,5xx表示伺服器端處理時發生了錯誤;
回應類型:由Content-Type指定;
以及其他相關的Header;
通常伺服器的HTTP回應會攜帶內容,也就是有一個Body,包含回應的內容,網頁的HTML來源碼就在Body中。

步驟3:如果瀏覽器還需要繼續向伺服器請求其他資源,例如圖片,就再次發出HTTP請求,重複步驟1、2。

Web採用的HTTP協定採用了非常簡單的請求-回應模式,從而大大簡化了開發。當我們編寫一個頁面時,我們只需要在HTTP請求中把HTML發送出去,不需要考慮如何附帶圖片、視頻等,瀏覽器如果需要請求圖片和視頻,它會發送另一個HTTP請求,因此,一個HTTP請求只處理一個資源(此時就可以理解為TCP協定中的短連接,每個連結只獲取一個資源,如需要多個就需要建立多個連結)
HTTP協定同時具備極強的擴展性,雖然瀏覽器請求的是的首頁,但是新浪在HTML中可以鏈入其他伺服器的資源,例如![](http://upload-images.jianshu.io/upload_images/6078268-6060a9b222ef1412.png?imageMogr2/ auto-orient/strip%7CimageView2/2/w/1240),從而將請求壓力分散到各個伺服器上,並且,一個站點可以連結到其他站點,無數個站點互相連結起來,就形成了World Wide Web,簡稱WWW。

2.HTTP格式


客戶端請求訊息

##服務端回應訊息
  • 每個HTTP請求和回應都遵循相同的格式,一個HTTP包含Header和Body兩部分,其中Body是可選的。

  • HTTP協定是一種文字協議,所以,它的格式也非常簡單。

    HTTP GET請求的格式:
    GET /path HTTP/1.1
    Header1: Value1
    Header2: Value2
    Header3: Value3
    每個Header一行一個,換行符號是\r \n或用os.linesep
    HTTP POST請求的格式:
    POST /path HTTP/1.1
    Header1: Value1
    Header2: Value2
    Header3: Value3

    body data goes here...

    當遇到連續兩個\r\n時,Header部分結束,後面的資料全部是Body。
    HTTP回應的格式:
    200 OK
    Header1: Value1
    Header2: Value2
    Header3: Value3

    body data goes here...

    HTTP回應如果包含body,也是透過\r\n\r\n來分隔的。
    請再次注意,Body的資料類型由Content-Type頭來決定,如果是網頁,Body就是文本,如果是圖片,Body就是圖片的二進位資料。
    當存在Content-Encoding時,Body資料是被壓縮的,最常見的壓縮方式是gzip,所以,看到Content-Encoding: gzip時,需要將Body資料先解壓縮,才能得到真正的資料。壓縮的目的在於減少Body的大小,加快網路傳輸。

    4Web靜態伺服器

    1.顯示固定的頁面

  • 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()
    登入後複製

客戶端瀏覽器頁面
2.顯示需要的頁面

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()
登入後複製

用戶端瀏覽器首頁

客戶端瀏覽器biye.html頁面
#


學習過程中遇到什麼問題或想取得學習資源的話,歡迎加入學習交流群組
343599877,我們一起學習前端!

以上是web伺服器的具體介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

電驢搜尋連不上伺服器如何解決 電驢搜尋連不上伺服器如何解決 Jan 25, 2024 pm 02:45 PM

電驢搜尋連不上伺服器如何解決

CentOS安裝fuse及CentOS安裝伺服器詳解 CentOS安裝fuse及CentOS安裝伺服器詳解 Feb 13, 2024 pm 08:40 PM

CentOS安裝fuse及CentOS安裝伺服器詳解

無法連接到RPC伺服器導致無法進入桌面的解決方法 無法連接到RPC伺服器導致無法進入桌面的解決方法 Feb 18, 2024 am 10:34 AM

無法連接到RPC伺服器導致無法進入桌面的解決方法

用PHP建構IP代理伺服器的最佳實務指南 用PHP建構IP代理伺服器的最佳實務指南 Mar 11, 2024 am 08:36 AM

用PHP建構IP代理伺服器的最佳實務指南

如何將Dnsmasq設定為DHCP中繼伺服器 如何將Dnsmasq設定為DHCP中繼伺服器 Mar 21, 2024 am 08:50 AM

如何將Dnsmasq設定為DHCP中繼伺服器

epic伺服器離線進不了遊戲怎麼辦? epic離線進不了遊戲解決方法 epic伺服器離線進不了遊戲怎麼辦? epic離線進不了遊戲解決方法 Mar 13, 2024 pm 04:40 PM

epic伺服器離線進不了遊戲怎麼辦? epic離線進不了遊戲解決方法

如何在伺服器上安裝 PHP FFmpeg 擴充功能? 如何在伺服器上安裝 PHP FFmpeg 擴充功能? Mar 28, 2024 pm 02:39 PM

如何在伺服器上安裝 PHP FFmpeg 擴充功能?

連接apple id伺服器時出錯怎麼辦 連接apple id伺服器時出錯怎麼辦 Feb 20, 2024 pm 03:30 PM

連接apple id伺服器時出錯怎麼辦

See all articles