自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一文看懂HTTP請求流程,不信你還不會(huì)

網(wǎng)絡(luò) 通信技術(shù)
HTTP 是一種允許瀏覽器向服務(wù)器獲取資源的協(xié)議,是 Web 的基礎(chǔ),通常由瀏覽器發(fā)起請求,用來獲取不同類型的文件, 例如 HTML 文件、CSS 文件、JavaScript 文件、圖片、視頻等。此外,HTTP 也是瀏覽器使用最廣的協(xié)議。

 

預(yù)備知識

OSI體系結(jié)構(gòu)TCP/IP相關(guān)協(xié)議結(jié)構(gòu)應(yīng)用層HTTP,Telnet,F(xiàn)TP等表示層會(huì)話層傳輸層TCP,UDP網(wǎng)絡(luò)層IP數(shù)據(jù)鏈路層物理層

了解到HTTP協(xié)議是建立在TCP連接基礎(chǔ)之上的。HTTP 是一種允許瀏覽器向服務(wù)器獲取資源的協(xié)議,是 Web 的基礎(chǔ),通常由瀏覽器發(fā)起請求,用來獲取不同類型的文件, 例如 HTML 文件、CSS 文件、JavaScript 文件、圖片、視頻等。此外,HTTP 也是瀏覽器使用最廣的協(xié)議。

我們對HTTP不太了解的話都會(huì)存在這樣的疑惑,為什么再次訪問同一站點(diǎn)會(huì)比第一次快,登錄過一次后的網(wǎng)站再次訪問就處于登錄狀態(tài)等,我們 通過對HTTP請求過程的剖析來解開這些謎團(tuán)。

瀏覽器端發(fā)起 HTTP 請求流程

瀏覽器輸入網(wǎng)址:http://time.geekbang.org/index.html,之后會(huì)完成什么步驟呢?

1、構(gòu)建請求

首先,瀏覽器構(gòu)建請求行信息,構(gòu)建好后,瀏覽器準(zhǔn)備發(fā)起網(wǎng)絡(luò)請求。

  1. GET /index.html HTTP1.1 

2、查找緩存

在真正發(fā)起網(wǎng)絡(luò)請求之前,瀏覽器會(huì)先在瀏覽器緩存中查詢是否有要請求的文件。其中,瀏覽器緩存是一種在本地保存資源副本,以供下次請求時(shí)直接使用的技術(shù)。

當(dāng)瀏覽器發(fā)現(xiàn)請求資源已經(jīng)存在瀏覽器緩存中存有副本,則會(huì)攔截請求并返回該資源副本結(jié)束請求。如果查找緩存失敗,則會(huì)進(jìn)入網(wǎng)絡(luò)請求。所以會(huì)有利于:

  • 緩解服務(wù)器端壓力,提升性能
  • 對于網(wǎng)站來說,緩存是實(shí)現(xiàn)快速資源加載的重要組成部分,減少了獲取資源的時(shí)間。

3、準(zhǔn)備IP地址和端口

我們通過開頭預(yù)備知識和前文也大概了解到了HTTP和TCP的關(guān)系。瀏覽器使用 HTTP 協(xié)議作為應(yīng)用層協(xié)議,用來封裝請求的文本信息;并使用 TCP/IP 作傳輸層協(xié)議將它發(fā)到網(wǎng)絡(luò)上,所以在 HTTP 工作開始之前,瀏覽器需要通過 TCP 與服務(wù)器建立連接。也就是說 HTTP 的內(nèi)容是通過 TCP 的傳輸數(shù)據(jù)階段來實(shí)現(xiàn)的。

TCP和HTTP的關(guān)系示意圖:

 

查缺補(bǔ)漏:一文看懂HTTP請求流程,不信你還不會(huì)

 

據(jù)此,我們可以知道建立HTTP網(wǎng)絡(luò)請求就是,通過URL地址來解析獲取IP和端口信息,建立服務(wù)器和TCP連接。我們通過前文《TCP協(xié)議》 說到了數(shù)據(jù)包都是通過IP地址傳輸給接收方的。而我們網(wǎng)站一般的地址都是域名,所以需要把域名和IP地址做映射關(guān)系,即解析IP地址的系統(tǒng)“域名系統(tǒng)(DNS)”解析出 IP地址,并獲取對應(yīng)端口號獲得建立連接的前置條件。換句話說,即瀏覽器請求DNS返回域名對應(yīng)的IP,而請求DNS時(shí)也會(huì)查詢DNS數(shù)據(jù)緩存服務(wù),判斷是否域名已解析過, 如果解析過則查詢直接使用,拿到IP后則判斷URL是否指明端口號,沒有則HTTP協(xié)議默認(rèn)時(shí)80端口。

4、等待TCP隊(duì)列

Chrome 有個(gè)機(jī)制,同一個(gè)域名同時(shí)最多只能建立 6 個(gè) TCP 連接,如果在同一個(gè)域名下同時(shí)有 10 個(gè)請求發(fā)生,那么其中 4 個(gè)請求會(huì)進(jìn)入排隊(duì)等待狀態(tài),直至進(jìn)行中的請求完成。當(dāng)然,如果當(dāng)前請求數(shù)量少于 6,會(huì)直接進(jìn)入下一步,建立 TCP 連接。

5、建立TCP連接

隊(duì)列等待結(jié)束后,TCP和服務(wù)器實(shí)現(xiàn)“三次握手”(前文TCP協(xié)議有描述),即客戶端和服務(wù)器發(fā)送三個(gè)數(shù)據(jù)包以確認(rèn)連接,實(shí)現(xiàn)瀏覽器和服務(wù)的連接。

6、發(fā)送HTTP請求

一旦建立了 TCP 連接,瀏覽器就可以和服務(wù)器進(jìn)行通信了。而 HTTP 中的數(shù)據(jù)正是在這個(gè)通信過程中傳輸?shù)摹?/p>

HTTP請求數(shù)據(jù)格式:

 

查缺補(bǔ)漏:一文看懂HTTP請求流程,不信你還不會(huì)

 

首先瀏覽器會(huì)向服務(wù)器發(fā)送請求行,它包括了請求方法、請求 URI(Uniform Resource Identifier)和 HTTP 版本協(xié)議。

其中請求方式有GET,POST,PUT,Delete等,其中常用的POST會(huì)用于發(fā)送一些數(shù)據(jù)給服務(wù)器,比如登錄網(wǎng)站把用戶信息發(fā)送給服務(wù)器,一般 這些數(shù)據(jù)會(huì)通過請求體發(fā)送。

在瀏覽器發(fā)送請求行命令之后,還要以請求頭形式發(fā)送其他一些信息,把瀏覽器的一些基礎(chǔ)信息告訴服務(wù)器。比如包含了瀏覽器所使用的操作系統(tǒng)、瀏覽器內(nèi)核等信息,以及當(dāng)前請求的域名信息、Cookie等。

服務(wù)器端處理 HTTP 請求流程

1、返回請求

  1. curl -i https://time.geekbang.org/ 

通過curl工具(或network面板)我們可以了解到服務(wù)器返回的數(shù)據(jù)格式:

 

查缺補(bǔ)漏:一文看懂HTTP請求流程,不信你還不會(huì)

 

首先服務(wù)器會(huì)返回響應(yīng)行,包括協(xié)議版本和狀態(tài)碼。

如果出現(xiàn)錯(cuò)誤,服務(wù)器會(huì)通過請求行的狀態(tài)碼來返回對應(yīng)的處理結(jié)果,例如:

  • 最常用的狀態(tài)碼是 200,表示處理成功;
  • 404,表示沒有找到頁面
  • 500,表示服務(wù)器錯(cuò)誤

正如瀏覽器會(huì)隨同請求發(fā)送請求頭一樣,服務(wù)器也會(huì)隨同響應(yīng)向?yàn)g覽器發(fā)送響應(yīng)頭。響應(yīng)頭包含了服務(wù)器自身的一些信息, 比如服務(wù)器生成返回?cái)?shù)據(jù)的時(shí)間、返回的數(shù)據(jù)類型(JSON、HTML、流媒體等類型),以及服務(wù)器要在客戶端保存的 Cookie 等信息。

響應(yīng)頭之后,服務(wù)器會(huì)發(fā)送響應(yīng)體數(shù)據(jù),通常包含了HTML的實(shí)際內(nèi)容。以上為服務(wù)器響應(yīng)瀏覽器的過程。

2、斷開連接

一旦服務(wù)器向客戶端返回了請求數(shù)據(jù),它就要關(guān)閉 TCP 連接。不過如果瀏覽器或者服務(wù)器在其頭信息中加入了:

  1. Connection:Keep-Alive 

則TCP 連接在發(fā)送后將仍然保持打開狀態(tài),這樣瀏覽器就可以繼續(xù)通過同一個(gè) TCP 連接發(fā)送請求。保持 TCP 連接可以省去下次請求時(shí)需要建立連接的時(shí)間,提升資源加載速度。 如果一個(gè)頁面內(nèi)嵌的圖片都來自同一web站點(diǎn),則初始化一個(gè)持久連接則可復(fù)用減少TCP的連接。

3、重定向

重定向返回響應(yīng)行和響應(yīng)頭:

 

查缺補(bǔ)漏:一文看懂HTTP請求流程,不信你還不會(huì)

 

狀態(tài) 301 就是告訴瀏覽器,我需要重定向到另外一個(gè)網(wǎng)址,而需要重定向的網(wǎng)址正是包含在響應(yīng)頭的 Location 字段中,接下來,瀏覽器獲取 Location 字段中的地址,并使用該地址重新導(dǎo)航,這就是一個(gè)完整重定向的執(zhí)行流程。

總結(jié)

通過http請求的完整過程,我們就知道,請求過程中DNS緩緩和頁面資源緩存會(huì)被瀏覽器緩存起來,以減少向服務(wù)器請求的資源,所以會(huì)再次請求站點(diǎn)時(shí)速度會(huì)快。

瀏覽器資源緩存處理過程:

 

查缺補(bǔ)漏:一文看懂HTTP請求流程,不信你還不會(huì)

 

從上圖的第一次請求可以看出,當(dāng)服務(wù)器返回 HTTP 響應(yīng)頭給瀏覽器時(shí),瀏覽器是通過響應(yīng)頭中的 Cache-Control 字段來設(shè)置是否緩存該資源。通常,我們還需要為這個(gè)資源設(shè)置一個(gè)緩存過期時(shí)長,而這個(gè)時(shí)長是通過 Cache-Control 中的 Max-age 參數(shù)來設(shè)置的。

因此在該緩存資源還未過期的情況下, 如果再次請求該資源,會(huì)直接返回緩存中的資源給瀏覽器。

如果緩存過期了,瀏覽器則會(huì)繼續(xù)發(fā)起網(wǎng)絡(luò)請求,并且在 HTTP 請求頭中帶上If-None-Match,服務(wù)器收到請求頭后,會(huì)根據(jù) If-None-Match 的值來判斷請求的資源是否有更新。

  • 如果沒有更新,就返回 304 狀態(tài)碼,相當(dāng)于服務(wù)器告訴瀏覽器,這個(gè)緩存可以繼續(xù)使用。
  • 如果資源有更新,服務(wù)器就直接返回最新資源給瀏覽器。

登錄網(wǎng)站,通過POST方式提交信息給服務(wù)器,服務(wù)器接收到瀏覽器提交的信息之后,查詢驗(yàn)證信息正確則會(huì)生成表面用戶身份的字符串寫入響應(yīng)頭的Set-Cookie字段里返回瀏覽器。

瀏覽器解析響應(yīng)頭,如有Set-Cookie字段則保存在本地,當(dāng)用戶再次訪問時(shí),發(fā)起HTTP請求前瀏覽器會(huì)讀取Cookie數(shù)據(jù)并寫入請求頭發(fā)送到服務(wù)器,服務(wù)器再次判斷信息,如果 正確則展示用戶登錄狀態(tài)及用戶信息。

最后總結(jié)出瀏覽器中的HTTP請求從發(fā)起到結(jié)束一共經(jīng)歷了八個(gè)階段:構(gòu)建請求、查找緩存、準(zhǔn)備 IP 和端口、等待 TCP 隊(duì)列、建立 TCP 連接、發(fā)起 HTTP 請求、服務(wù)器處理請求、服務(wù)器返回請求和斷開連接。

詳細(xì)HTTP請求流程:

 

查缺補(bǔ)漏:一文看懂HTTP請求流程,不信你還不會(huì)

 

 

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2020-03-10 08:33:04

HTTP演變協(xié)議

2024-08-12 12:30:27

2020-03-31 14:40:24

HashMap源碼Java

2018-05-21 10:20:22

人工智能機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)

2018-02-02 11:17:42

IaaSPaaSSaaS

2016-08-18 00:21:12

網(wǎng)絡(luò)爬蟲抓取網(wǎng)絡(luò)

2021-04-26 10:30:43

USB4設(shè)備Thunderbolt

2025-01-20 09:15:00

iOS 18.3蘋果iOS 18

2021-08-02 06:56:19

TypeScript編程語言編譯器

2019-07-01 09:22:15

Linux操作系統(tǒng)硬件

2019-05-22 09:50:42

Python沙箱逃逸網(wǎng)絡(luò)攻擊

2018-10-08 15:00:27

物聯(lián)網(wǎng)LoRaIOT

2021-02-21 11:25:17

云計(jì)算IaaSPaaS

2021-05-11 10:40:29

JUCAQSJava

2021-05-12 15:16:17

JUCAQSJava

2024-10-10 17:55:57

LinuxACL訪問控制列表

2022-12-07 07:38:07

存儲(chǔ)管理HSM

2023-12-18 10:45:31

2019-02-13 15:38:09

存儲(chǔ)虛擬化云計(jì)算

2022-04-26 13:41:16

區(qū)塊鏈比特幣數(shù)據(jù)庫
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號