HTTP 協議簡介

2021-09-02 22:30:21 字數 3205 閱讀 8237

引言

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

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

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

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

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

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

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

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

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

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

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

四、get與post區別

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

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

403 forbidden                 //對被請求頁面的訪問被禁止

404 not found //請求資源不存在,比如:輸入了錯誤的url

更多看下這篇文章《兩張趣圖助你理解 http 狀態碼

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

為解決上述 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協議簡介

現在web發展如火如荼,web開發人員也越來越多,但有幾個對支援web的http協議有了解呢?底層協議基礎不紮實,高層應用是很難做到極致的。帶著好奇心,開始學習吧!http hypertext transfer protocol 即超文字傳輸協議,是瀏覽器和伺服器之間互相通訊的一種約定,通過網際網路...

HTTP協議 簡介

全稱為超文字傳輸協議 hypertext transfer protocol 設計之初是為了將超文字標記語言 html 文件從web伺服器傳送到客戶端的瀏覽器。現在http的作用已不侷限於html的傳輸。url url示例 解釋 scheme 指定低層使用的協議 例如 http,https,ftp ...

http協議簡介

摘要 本文 go web程式設計 一書,覺得說的比較好,特轉過來收藏。我們平時瀏覽網頁的時候,會開啟瀏覽器,輸入 後按下回車鍵,然後就會顯示出你想要瀏覽的內容。在這個看似簡單的使用者行為背後,到底隱藏了些什麼呢?對於普通的上網過程,系統其實是這樣做的 瀏覽器本身是乙個客戶端,當你輸入url的時候,首...