HTTP 協議極簡教程

2021-09-01 11:49:02 字數 3497 閱讀 5766

引言

http協議是hyper text transfer protocol(超文字傳輸協議)的縮寫,是用於從全球資訊網伺服器傳輸超文字到本地瀏覽器的傳送協議。http 是基於 tcp/ip 協議通訊協議來傳遞資料(html 檔案、檔案、查詢結果等)。它不涉及資料報(packet)傳輸,主要規定了客戶端和伺服器之間的通訊格式,預設使用80埠。

一、http的特點

2、靈活:http允許傳輸任意型別的資料物件。

3、無連線:無連線的含義是限制每次連線只處理乙個請求。伺服器處理完客戶的請求,並收到客戶的應答後,即斷開連線。採用這種方式可以節省傳輸時間。

二、http報文

http報文包括請求報文和響應報文兩大部分,其中請求報文由請求行(request line)、請求頭(header)、空行和請求體四個部分組成。而響應報文由狀態行、響應頭部、空行和響應體四個部分組成。接下來我們詳細介紹下請求報文的各個部分及其作用。

1、請求行

用來說明請求型別、要訪問的資源以及所使用的http版本。

post  /chapter17/user.html http/1.1以上**中post代表請求方法,/chapter17/user.html表示uri,http/1.1代表協議和協議的版本。現在比較流行的是http1.1版本。大家也可以了解下 2.0 :《讓面試官顫抖的 http 2.0 協議面試題》。

2、請求頭

由關鍵字/值對組成,每行一對,關鍵字和值用英文冒號「:」分隔。

請求頭部通知伺服器有關於客戶端請求的資訊。它包含許多有關的客戶端環境和請求正文的有用資訊。其中比如:

3、空行

最後乙個請求頭之後是乙個空行,這個行非常重要,它表示請求頭已經結束,接下來的是請求正文。

4、請求體

可以承載多個請求引數的資料。

name=tom&password=1234&realname=tomson上面**,承載著name、password、realname三個請求引數。

三、http請求方法

四、get與post區別

五、http狀態碼

狀態**有三位數字組成,第乙個數字定義了響應的類別,共分五種類別:

比如我們平時常見兩種出錯的狀態碼:

403 forbidden                 //對被請求頁面的訪問被禁止404 not found                 //請求資源不存在,比如:輸入了錯誤的url更多看下這篇文章《兩張趣圖助你理解 http 狀態碼》 

六、持久連線

1、為什麼需要持久連線

http協議的初始版本中,每進行一次http通訊就要斷開一次tcp連線。以當年的通訊情況來說,因為都是些容量很小的文字傳輸,所以即使這樣也沒有多大問題。可隨著 http 的 普及,文件中包含大量的情況多了起來。比如,使用瀏覽器瀏覽乙個包含多張的 html 頁面時,在傳送請求訪問 html 頁面資源的同時,也會請 求該 html 頁面裡包含的其他資源。因此,每次的請求都會造成無謂的 tcp 連線建立和斷開,增加通訊量的 開銷。

2、持久連線的特點

為解決上述 tcp 連線的問題,http/1.1和一部分的http/1.0想出了持久連線(http persistent connections,也稱為 http keep-alive 或 http connection reuse)的方法。持久連線的特點是,只要任意一端沒有明確提出斷開連線,則保持tcp連線狀態。

持久連線的好處在於減少了 tcp 連線的重複建立和斷開所造成的額外開銷,減輕了伺服器端的負載。另外, 減少開銷的那部分時間,使 http 請求和響應能夠更早地結束,這樣 web 頁面的顯示速度也就相應提高了。

http/1.1中,所有的連線預設都是持久連線,但在http/1.0內並未標準化。雖然有一部分伺服器通過非 標準的手段實現了持久連線,但伺服器端不一定能夠支援持久連線。毫無疑問,除了伺服器端,客戶端也需 要支援持久連線。

七、管線化

持久連線使得多數請求以管線化(pipelining)方式傳送成為可能。從前傳送請求後需等待並收到響應,才能 傳送下乙個請求。管線化技術出現後,不用等待響應亦可直接傳送下乙個請求。

這樣就能夠做到同時並行傳送多個請求,而不需要乙個接乙個地等待響應了。通俗地講,請求打包一次傳輸過去,響應打包一次傳遞回來。管線化的前提是在持久連線下。

假如當請求乙個包含 10 張的 html web 頁面,與挨個連線相比,用持久連線可以讓請求更快結束。 而管線化技術則比持久連線還要快。請求數越多,時間差就越明顯。客戶端需要請求這十個資源。以前的做法是,在同乙個tcp連線裡面,先傳送a請求,然後等待伺服器做出回應,收到後再發出b請求,以此類推,而管道機制則是允許瀏覽器同時發出這十個請求,但是伺服器還是按照順序,先回應a請求,完成後再回應b請求。

於是在使用持久連線的情況下,某個連線上訊息的傳遞類似於:

請求1 -> 響應1 -> 請求2 -> 響應2 -> 請求3 -> 響應3

管線化方式傳送變成了類似這樣:

請求1 -> 請求2 -> 請求3 -> 響應1 -> 響應2 -> 響應3

HTTP 協議極簡教程

http協議是hyper text transfer protocol 超文字傳輸協議 的縮寫,是用於從全球資訊網伺服器傳輸超文字到本地瀏覽器的傳送協議。http 是基於 tcp ip 協議通訊協議來傳遞資料 html 檔案 檔案 查詢結果等 它不涉及資料報 packet 傳輸,主要規定了客戶端和伺...

漫畫 HTTP 協議極簡教程,傻瓜都能看懂!

一 http的特點 二 http報文 1 請求行 post代表請求方法,chapter17 user.html表示uri,http 1.1代表協議和協議的版本。現在比較流行的是http1.1版本。大家也可以了解下 2.0 讓面試官顫抖的 http 2.0 協議面試題 2 請求頭 值對組成,每行一對,...

Shell 極簡教程

vim hello world.sh bin bash echo hello world chmod x sh hello world.sh hello,world bin bash echo hello,world a 1b expr a 1 echo b注意,變數名和等號之間不能有空格,這可能和...