前言
在HTTP請求中蓬衡,消息報文分為Request和Response兩種
例如:下邊就是一個HTTP請求報文
POST /chd/api/settlement/guangdong/monthly/accounting HTTP/1.1
Content-Type: application/json
Accept:
Accept-Language: zh-CN,zh-Hans;q=0.9
Accept-Encoding: gzip, deflate
Host: localhost:3000
Origin: http://localhost:3000
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15
Connection: keep-alive
Referer: http://localhost:3000/settlementbi/electricityBilling
Content-Length: 58
Cookie:
domain
visitSource: em
Request消息主要包括四部分:
- 請求行
- 請求頭
- 空行
- 請求體
一、請求行request-line
請求行中彤枢,包括三部分:
- 請求方法:
post
狰晚、get
等 - URL地址
- 協(xié)議的版本:
HTTP/1.1
請求行中,三部分內(nèi)容用空格分割
二缴啡、請求頭
請求頭headers用于指定服務(wù)器要使用的附加信息
部分請求頭是瀏覽器會自動添加的壁晒,當(dāng)然也可以添加自定的請求頭
1. HOST
HOST標(biāo)識請求的目的地
HOST主要用來指定被請求資源的Internet主機(jī)和端口號,它通常從請求的URL中提取出來
2. User-Agent
- User-Agent記錄著客戶端的詳細(xì)信息业栅,服務(wù)器可通過User-Agent判斷當(dāng)前HTTP請求客戶端的類別秒咐。
- User-Agent表示服務(wù)器和客戶端腳本都能夠訪問它,是客戶端類型檢測邏輯的重要基礎(chǔ)碘裕。
User-Agent由客戶端(瀏覽器)來定義且會在每個請求中自動發(fā)送
3. Accept
Accept的作用携取,是向服務(wù)器申明客戶端可以接收的媒體類型(MIME)的資源,簡單來說就是表示客戶端支持的MIME類型帮孔。
Accept媒體類型中的先后次序表示客戶端接收的先后順序
Accept中可以使用通配符/表示任意類型的數(shù)據(jù)
4. Accept-Language
Accept-Language指定HTTP請求返回信息時優(yōu)先選擇的語言
例如:Accept-Language: zh-cn,zh;q=0.5
客戶端支持的語言分別是中文和簡體中文歹茶,優(yōu)先支持簡體中文。
q 表示權(quán)重系數(shù)你弦,范圍0~1,q值越大請求越傾向于獲取;之前的類型所表示的內(nèi)容燎孟,若沒有指定q值則默認(rèn)為1禽作。若q值為0則用于提醒服務(wù)器哪些是瀏覽器不接受的內(nèi)容類型。
5. Accept-Encoding
Accept-Encoding允許服務(wù)器將輸出內(nèi)容發(fā)回客戶端之前進(jìn)行壓縮揩页,以節(jié)約帶寬旷偿。這里設(shè)置的就是客戶端所能夠支持的壓縮格式。
例如:Accept-Encoding: gzip,deflate
6. Accept-Charset
Accept-Charset指定客戶端可以接受的字符編碼集爆侣。
例如:Accept-Charset: gb2312, utf-8; q=0.7, *;q=0.7
瀏覽器支持的字符編碼分別是gb2312萍程、utf-8和任意字符,優(yōu)先順序為gb2312兔仰、utf-8茫负、*。
7. Content-Type
Content-Type表示HTTP請求提交的內(nèi)容類型乎赴,只有在POST方法提交時才需要設(shè)置此屬性忍法。
例如:Content-Type: application/x-www-form-urlencoded;charset:UTF-8
8. Content-Length
Content-Type是請求體內(nèi)容的長度潮尝,單位字節(jié)(byte)
并不包含請求行和請求頭的數(shù)據(jù)長度。
9. Connection
Connection表示是否需要持久連接饿序,如果服務(wù)器接收到Connection的屬性值為Keep-Alive勉失,或者請求所使用的協(xié)議版本是HTTP 1.1(默認(rèn)持久連接),此時就會采用持久連接原探。
可以利用持久連接的優(yōu)點乱凿,當(dāng)頁面包含多個元素時,可以顯著的減少下載所需的時間咽弦。要實現(xiàn)這一點徒蟆,Web服務(wù)器需要在返回給客戶端的HTTP頭信息中加入Content-Length信息正文的長度。
- 用法1:
Connection: keep-alive
當(dāng)一個Web頁面打開時离唬,客戶端和服務(wù)器之間用于傳輸HTTP數(shù)據(jù)庫的TCP連接不會關(guān)閉后专,如果客戶端再次訪問Web服務(wù)器上的網(wǎng)頁,會繼續(xù)使用這條已經(jīng)建立的連接输莺。
- Connection: close
close表示一個Requset請求完成后戚哎,客戶端和Web服務(wù)器之間用于傳輸HTTP數(shù)據(jù)的TCP連接會關(guān)閉,當(dāng)客戶端再次發(fā)送Request請求時嫂用,需要重新建立TCP連接型凳。
10. Keep-Alive
Keep-Alive指定HTTP持久連接的時長,用來保證客戶端到服務(wù)器的連接持續(xù)有效嘱函。當(dāng)出現(xiàn)對服務(wù)器的后續(xù)請求時甘畅,Keep-Alive可以避免重建連接。
早期的HTTP請求是一站式連接往弓,從HTTP協(xié)議1.1版本之后就開始支持長連接疏唾。長連接簡單來說,就是在Keep-Alive規(guī)定的時間內(nèi)連接不會斷開函似。
例如:Keep-Alive:300
11. Cookie
Cookie用來存放一些用戶身份的數(shù)據(jù)
12. Refer
Refer包含了一個URL槐脏,表示用戶從該URL頁面觸發(fā)訪問當(dāng)前請求的頁面。
13. Cache-Control
Cache-Control用于指定請求和響應(yīng)遵循的緩存機(jī)制撇寞。
在請求消息或響應(yīng)消息中設(shè)置Cache-Control并不會修改另一個消息處理過程中的緩存處理過程
請求時的緩存指令包含:
-
no-cache
指示請求或響應(yīng)消息不能緩存顿天,只能應(yīng)用于HTTP1.1。 -
no-store
用于防止重要的信息被無意的發(fā)布蔑担,在請求消息中發(fā)送將使得請求和響應(yīng)消息都不使用緩存牌废。 -
max-age
指示客戶端可以接收生存期不大于指定時間的響應(yīng),以秒為單位啤握。 -
max-stale
指示客戶端可以接收超出超時期間的響應(yīng)消息鸟缕,如果指定max-stale消息的值,那么客戶端可以接收超出超時期指定值之內(nèi)的響應(yīng)消息恨统。 -
min-fresh
指示客戶端可以接收響應(yīng)時間小于當(dāng)前時間加上指定時間的響應(yīng) -
only-if-cached
表示不進(jìn)行網(wǎng)絡(luò)請求叁扫,完全只使用緩存三妈,若緩存不命中,則返回503錯誤
三莫绣、空行
空行畴蒲,就是用于分割POST請求的請求頭,和請求體的对室。
四模燥、請求體
請求體,主要封裝的是POST請求消息的請求參數(shù)掩宜;