詳解前端HTTP協議入門教程

52bdqn發表於2018-06-07
下面給介紹一下http協議的入門,實際上前端功能會在實際開發中經常的接觸瀏覽器網路相關的,一共四個部分。

1、原因

如圖,那麼為什麼要在前端進階裡面會給大家介紹http協議,因為絕大多少的web應用,都是構建在http協議之上的。

2、是什麼

簡單來說http協議是一種無狀態、B/S(瀏覽器和伺服器)模式應用層協議,多基於TCP協議。

3、包含什麼

現在我們來分析我想要介紹的http協議都包含什麼內容?

因為http協議它是一種瀏覽器、伺服器模式的應用程式,那麼它肯定包含請求也包含響應,這裡我要講的是請求裡面包含些什麼東西,和響應裡面還包含什麼東西,請求裡面報文的格式包括報頭、正文、URI,然後還有請求方法和請求頭等等,響應裡面包括響應的狀態碼、訊息報頭還有響應正文。

4、FAQ

還有一些大家在學習的過程中,經常會遇到的一些問題,比如說常見的請求頭有哪些?比如說“user-aget”“cookle”“Referrer”還有常見的響應頭“Content-Type”“Content-Length”“Cache”,還有控制資源快取的一些內容,還有常見的狀態碼也就是響應的狀態碼,狀態碼中的“2xx”表示請求是成功的或者是傳出內容,“3xx”表示跳轉,“4xx”表示客戶端請求錯誤,“5xx”表示伺服器端錯誤。

那麼為了給大家詳細介紹一個http請求和響應部分。


如圖,開啟谷歌瀏覽器的開發者工具,在右上角有三個橫槓的符號,點選這個符號,然後選擇更多工具“more tools”然後點開開發者工具就可以出現。



如圖,然後點到下面,然後在列表裡面看第一個,然後可以看到“Request headers”就是請求頭,可以看到它下面有幾個關鍵的,比如說“accept”就是你能夠接受什麼型別的編碼,還有你是否支援壓縮等等。

然後還有一個比較關鍵的是“cookie”,因為前面有提到http是一種無連線,無狀態的一種協議,就是在兩個請求之間,下一個請求是不知道上一個請求的狀態的,所以為了解決這個問題就引入了“cookie”。

還有就是“referer”就是跳轉到當前的這個頁面,我是從哪個頁面來的,這個在做網站統計的時候是非常有用的東西,因為這個referer在瀏覽器的安全策略裡面是不允許改的,就是別人是控制不了這個referer。



如圖,還有一個比較重要的叫做“user agent”,這個簡單的理解就是使用者代理,這個就是一個標示當前瀏覽器的東西。


如圖,剛才我所說的“Request Headers”它就是一個請求頭,那麼http具體的請求實際上第一行是這個內容,然後後面才是請求頭。



如圖,這才是真正的請求,如圖上加綠部分就代表我當前請求的是什麼東西,然後是用“GET”方法請求的,然後是我拿到的響應狀態碼是200。


如圖,可以看到響應狀態碼在這裡,首先是協議然後是狀態碼,然後是ok。“content-type”這是比較重要的響應頭,那麼content標示的是當前傳輸內容的型別,就是http協議限制就是一次連結只查出一種型別的內容,但是http2裡面打破了這種限制。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/25876358/viewspace-2155810/,如需轉載,請註明出處,否則將追究法律責任。

相關文章