一、http狀態(tài)碼
1、引例闡述
在講狀態(tài)嗎之前,我們先來了解什么是狀態(tài)碼。比如百度網(wǎng)站:

大家可以看到,上圖中圈紅圈的部分就是 http
的狀態(tài)碼,常見的狀態(tài)碼有200,400,404等等。接下來對狀態(tài)碼的一些基礎(chǔ)知識進(jìn)行介紹。
2、狀態(tài)碼分類
下表給出狀態(tài)碼分類。
狀態(tài)碼 | 含義 | 解釋說明 |
---|
1xx | 服務(wù)器收到請求 | 收到1xx開頭的請求表示服務(wù)端已經(jīng)收到請求,但是還沒有返回信息給客戶端 |
2xx | 請求成功,如200 | 表示客戶端已經(jīng)成功請求數(shù)據(jù) |
3xx | 重定向,如302 | 客戶端收到3xx開頭的狀態(tài)碼時(shí),表示此時(shí)服務(wù)端已經(jīng)不再管客戶端所請求地址,讓客戶端去請求另外的地址 |
4xx | 客戶端錯(cuò)誤,404 | 表示當(dāng)客戶端請求了一個(gè)服務(wù)端完全不認(rèn)識的地址時(shí),就會報(bào)出4xx的錯(cuò)誤 |
5xx | 服務(wù)端錯(cuò)誤,如500 | 表示此錯(cuò)誤來源于服務(wù)端,比如服務(wù)端寫的接口出現(xiàn)了bug等問題 |
3、常見狀態(tài)碼
常見的有200(正常) 、404(無法找到該網(wǎng)頁資源) 、304(跳轉(zhuǎn)頁面) 、500(服務(wù)器錯(cuò)誤)等,具體如下:
狀態(tài)碼 | 含義 | 用途 |
---|
200 | OK 成功 | 一般用于 GET 和 POST 請求 |
301 | Redirect Permanently 永久重定向 | 配合location,瀏覽器自動處理 |
302 | Found 臨時(shí)重定向 | 配合location,瀏覽器自動處理 |
304 | Not Modified 資源未被修改 | 所請求的資源未修改,服務(wù)器返回此狀態(tài)碼時(shí),不會返回任何資源??蛻舳送ǔ彺嬖L問過的資源,通過提供一個(gè)頭信息指出客戶端希望只返回在指定日期之后修改的資源 |
404 | Not Found 資源未找到 | 服務(wù)器無法根據(jù)客戶端的請求找到資源(網(wǎng)頁)。通過此代碼,網(wǎng)站 設(shè)計(jì)人員可設(shè)置"您所請求的資源無法找到"的個(gè)性頁面 |
403 | Forbidden 沒有權(quán)限 | 服務(wù)器理解請求客戶端的請求,但是拒絕執(zhí)行此請求 |
500 | Internal server Error 服務(wù)器錯(cuò)誤 | 服務(wù)器內(nèi)部錯(cuò)誤 |
504 | Gateway Time-out網(wǎng)關(guān)超時(shí) | 充當(dāng)網(wǎng)關(guān)或代理的服務(wù)器,未及時(shí)從遠(yuǎn)端服務(wù)器獲取請求 |
下面詳細(xì)闡述 301
和 302
。
301 永久重定向:
常見場景有,比如說你的一個(gè)網(wǎng)站,域名到期了,或者域名你不想用了,那么老的域名就可以返回一個(gè) 301
狀態(tài)碼并配合 location
讓 location
的值等于新的域名,最終進(jìn)行跳轉(zhuǎn),之后瀏覽器會記住新的域名,不會再訪問老的域名。
302 臨時(shí)重定向:
常見場景有百度,知乎、簡書等等。比如說我們要在百度進(jìn)入菜鳥教程,搜索出來后有一系列的列表,我們可以選擇一個(gè)去進(jìn)行一個(gè)點(diǎn)擊。點(diǎn)擊的那個(gè)不會直接進(jìn)入菜鳥教程,而是先跳轉(zhuǎn)到百度設(shè)置的一個(gè)臨時(shí)地址,之后再跳轉(zhuǎn)到菜鳥教程真實(shí)的地址。
4、關(guān)于協(xié)議和規(guī)范
二、http 方法
1、傳統(tǒng)的methods
2、現(xiàn)在的methods
get 獲取數(shù)據(jù);
post 新建數(shù)據(jù);
patch/put 更新數(shù)據(jù);
delete 刪除數(shù)據(jù);
head,類似于get請求,只不過返回的響應(yīng)中沒有具體的內(nèi)容,用戶獲取報(bào)頭;
options,允許客戶端查看服務(wù)器的性能,比如說服務(wù)器支持的請求方式等等;
trace,追蹤路徑;
connect,要求用隧道協(xié)議連接代理。
3、Restful API
(1)Restful API是什么?
Restful API
是一種新的 API
設(shè)計(jì)方法(早已推廣使用)。
傳統(tǒng) API
設(shè)計(jì):把每個(gè) url
當(dāng)做一個(gè)功能。
Restful API
設(shè)計(jì):把每個(gè) url
當(dāng)做一個(gè)唯一的資源。
(2)如何設(shè)計(jì)成一個(gè)資源?
1)盡量不用url參數(shù)
2)用method表示操作類型
傳統(tǒng) API
設(shè)計(jì):
post請求:/api/create-article
post請求:/api/update-article?id=100
get請求:/api/get-article?id=100
Restful API
設(shè)計(jì):
post請求:/api/article
post請求:/api/article/100
get請求:/api/article/100
三、http 頭部(http headers)
1、常見的Request headers
請求頭 | 含義 |
---|
Accept | 瀏覽器可接收的數(shù)據(jù)格式 |
Accept-Encoding | 瀏覽器可以接收的算法,如gzip |
Accept-Language | 瀏覽器可接收的語言,如zh-CN |
Connection | keep-alive 一次TCP連接重復(fù)使用 |
cookie | 客戶端接收到的Cookie信息 |
Host | 指定原始的 URL 中的主機(jī)和端口 |
User-Agent(簡稱UA) | 瀏覽器內(nèi)核信息 |
Content-type | 發(fā)送數(shù)據(jù)的格式,如application/json |
2、常見的Response headers
響應(yīng)頭 | 含義 |
---|
Content-type | 返回?cái)?shù)據(jù)的格式,如application/json |
Content-length | 返回?cái)?shù)據(jù)的大小,多少字節(jié) |
Content-Encoding | 返回?cái)?shù)據(jù)的壓縮算法,如gzip |
Set-Cookie | 服務(wù)端向客戶端設(shè)置cookie |
四、http 緩存
1、關(guān)于緩存的介紹
(1)什么是緩存
緩存是一種保存資源副本并在下次請求時(shí)直接使用該副本的技術(shù)。
(2)為什么需要緩存?
如果沒有緩存的話,每一次網(wǎng)絡(luò)請求都要加載大量的圖片和資源,這會使頁面的加載變慢許多。那緩存的目的其實(shí)就是為了盡量減少網(wǎng)絡(luò)請求的體積和數(shù)量,讓頁面加載的更快。
(3)哪些資源可以被緩存?——靜態(tài)資源(js、css、img)
2、http 緩存策略(強(qiáng)制緩存 + 協(xié)商緩存)
(1)強(qiáng)制緩存
1)強(qiáng)制緩存是什么?
強(qiáng)制緩存就是文件直接從本地緩存中獲取,不需要發(fā)送請求。
2)圖例
先看第一個(gè)圖。

從上圖可以看到,當(dāng)初次請求時(shí),瀏覽器會向服務(wù)器發(fā)起請求,服務(wù)器接收到瀏覽器的請求后,返回資源并返回一個(gè) Cache-Control
給客戶端,該 Cache-Control
一般設(shè)置緩存的最大過期時(shí)間。
接下來看第二個(gè)圖。

從上圖中可以看到,此時(shí)瀏覽器已經(jīng)接收到 cache-control
的值,那么這個(gè)時(shí)候?yàn)g覽器再次發(fā)送請求時(shí),它會先檢查它的 cache-control
是否過期,如果沒有過期則直接從本地緩存中拉取資源,返回到客戶端,而無需再經(jīng)過服務(wù)器。
接下來看第三個(gè)圖。

強(qiáng)制緩存有過期時(shí)間,那么就意味著總有一天緩存會失效。那么假設(shè)某一天,客戶端的 cache-control
失效了,那么它就沒辦法從本地緩存中拉取資源。于是它會像第一張圖一樣,重新向服務(wù)器發(fā)起請求,之后服務(wù)器會再次返回資源和 cache-control
的值。
以上就是強(qiáng)制緩存的全過程。
3)Cache-Control
Cache-Control是什么?
Cache-Control的值
Cache-Control值 | 含義 |
---|
max-age | 設(shè)置緩存的最大過期時(shí)間 |
no-cache | 不用本地緩存,正常的向服務(wù)端請求,服務(wù)端怎么處理我們不用管 |
no-store | 簡單粗暴,直接從服務(wù)端拉取緩存 |
private | 只能允許最終用戶做緩存,最終用戶即電腦、手機(jī)等等 |
public | 允許中間路由或中間代理做緩存 |
4)關(guān)于Expires
(2)協(xié)商緩存
1)協(xié)商緩存是什么?
2)圖例
同樣地,用幾張圖來演示協(xié)商緩存。
先來看第一張圖。

在上圖中,表明了協(xié)商緩存的全過程。首先,如果客戶端是第一次向服務(wù)器發(fā)出請求,則服務(wù)器返回資源和相對應(yīng)的資源標(biāo)識給瀏覽器。該資源標(biāo)識就是對當(dāng)前所返回資源的一種唯一標(biāo)識,可以是Etag或者是Last-Modified,這兩個(gè)字段將在圖例結(jié)束后展開講解。
之后如果瀏覽器再次發(fā)送請求時(shí),瀏覽器就會帶上這個(gè)資源標(biāo)識。此時(shí),服務(wù)端就會通過這個(gè)資源標(biāo)識,可以判斷出瀏覽器的資源跟服務(wù)端此時(shí)的資源是否一致,如果一致,則返回304,即表示Not Found 資源未修改。如果判斷結(jié)果為不一致,則返回200,并返回資源以及新的資源標(biāo)識。至此就結(jié)束了協(xié)商緩存的過程。
接下來看第二張圖。

假設(shè)此時(shí)我們的協(xié)商緩存用 Last-Modified
來判斷。當(dāng)瀏覽器第一次發(fā)送請求時(shí),服務(wù)器返回資源并返回一個(gè) Last-Modified
的值給瀏覽器。這個(gè) Last-Modified
的值給到瀏覽器之后,瀏覽器會通過 If-Modified-Since
的字段來保存 Last-Modified
的值,且 If-Modified-Since
保存在請求頭當(dāng)中。
之后當(dāng)瀏覽器再次發(fā)送請求時(shí),請求頭會帶著 If-Modified-Since
的值去找服務(wù)器,服務(wù)器此刻就會匹配瀏覽器發(fā)過來的 If-Modified-Since
是否和自己最后一次修改的 Last-Modified
的值相等。如果相等,則返回 304
,表示資源未被修改;如果不相等,則返回200,并返回資源和新的 Last-Modified
的值。
接下來看第三張圖。

假設(shè)此時(shí)我們的協(xié)商緩存用 Etag
來判斷。當(dāng)瀏覽器第一次發(fā)送請求時(shí),服務(wù)器返回資源并返回一個(gè) Etag
的值給瀏覽器。這個(gè) Etag
的值給到瀏覽器之后,瀏覽器會通過 If-None-Match
的字段來保存 Etag
的值,且 If-None-Match
保存在請求頭當(dāng)中。
之后當(dāng)瀏覽器再次發(fā)送請求時(shí),請求頭會帶著 If-None-Match
的值去找服務(wù)器,服務(wù)器此刻就會匹配瀏覽器發(fā)過來的 If-None-Match
是否和自己最后一次修改的 Etag
的值相等。如果相等,則返回 304
,表示資源未被修改;如果不相等,則返回 200
,并返回資源和新的 Etag
的值。
通過圖例,相信大家對協(xié)商緩存有了一個(gè)新的認(rèn)識。接下來講解剛剛圖例中所包含的一些字段。
3)資源標(biāo)識
在響應(yīng)頭部 Response Headers
中,有兩種資源標(biāo)識:
4)Last-Modified 和 Etag
5)Headers 示例

由上圖可以看到,響應(yīng)頭中的 Last-Modified
對應(yīng)請求頭中的 If-Modified-Since
, Etag
對應(yīng)請求頭中的 If-None-Match
。
6)流程圖
說到這里,協(xié)商緩存的內(nèi)容也快結(jié)束啦!最后的最后,我們用一張流程圖來展示協(xié)商緩存的全過程。

7)協(xié)商緩存為什么要有兩種呢?
有時(shí)候我們的網(wǎng)站是分布式部署在多臺服務(wù)器上,一個(gè)資源文件可能在每臺服務(wù)器上都有副本,相應(yīng)地資源文件被修改時(shí),新的文件要同步到各個(gè)服務(wù)器上,導(dǎo)致各個(gè)文件副本的修改時(shí)間不一定相同。那么當(dāng)用戶一次訪問請求的服務(wù)器和另一次訪問請求的服務(wù)器不同時(shí),就有可能因?yàn)閮蓚€(gè)文件副本的修改時(shí)間不同而使得Last-Modified
形式的協(xié)商緩存失效。
如果這種情況采用Etag
形式的協(xié)商緩存,根據(jù)文件內(nèi)容而不是修改時(shí)間來判斷緩存,就不會有這個(gè)問題了。
3、刷新操作方式,對緩存的影響
講完緩存,我們再來講個(gè)有點(diǎn)重要但是有點(diǎn)題外話的內(nèi)容:刷新操作。我們平常在上網(wǎng)時(shí),總有某個(gè)時(shí)刻突然網(wǎng)卡了,這個(gè)時(shí)候人的本性總是非常不耐煩的,毫不猶豫的就來個(gè)刷新。但殊不知,刷新對緩存也存在一定的影響。下面我們一起來看下各種刷新姿勢以及其對緩存的影響。
(1)正常操作
定義: 地址欄輸入 url
,跳轉(zhuǎn)鏈接,前進(jìn)后退等。
對緩存的影響: 強(qiáng)制緩存有效,協(xié)商緩存有效。
(2)手動刷新
定義: F5
,點(diǎn)擊刷新按鈕,右擊菜單刷新。
對緩存的影響: 強(qiáng)制緩存失效,協(xié)商緩存有效。
(3)強(qiáng)制刷新
定義: ctrl
+ F5
。
對緩存的影響: 強(qiáng)制緩存失效,協(xié)商緩存失效。
這一塊內(nèi)容僅當(dāng)娛樂補(bǔ)充,大家可以根據(jù)自身需求學(xué)習(xí)~