1.http协议
http全称Hypertext Transfer Protocol超文本传输协议,该协议用于规定客户端和服务端之间的传输规则。客户端按照协议规则格式向服务端发出请求,服务端从而也就能够根据规则格式做出解析,同理,服务端也会按照协议规则做出响应,客户端也就能够根据规则做出解析。
2.http请求(Request)内容
如图所示,一个完整的request包含request line、header、和body。同时需要注意的是,图中的CRLF也是必不可少的。
下面通过charles抓的一个http请求展开分析 http://www.jianshu.com/p/q81RER
GET /p/q81RER HTTP/1.1
Host: www.jianshu.com
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Upgrade-Insecure-Requests: 1
Cookie: _session_id=xxxxx; remember_user_token=xxx; Hm_lpvt_0c0e9d9b1e7d617b3e6842e85b9fb068=1493626002; Hm_lvt_0c0e9d9b1e7d617b3e6842e85b9fb068=1493550585,1493622639,1493623143,1493625980; _ga=GA1.2.487162296.1493344586; _gat=1
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/10.1 Safari/603.1.30
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
Connection: keep-alive
- 请求行Request Line
// method+空格+URI+httpVersion+CRLF
GET /p/q81RER HTTP/1.1
method 就是我们平时所说的get、post等请求方式。
** URI** 就是URL中排除掉Host剩下的部分,也就是资源在服务器本地上的路径
** httpVersion** http版本号
- 请求头Request Header
Host: www.jianshu.com
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Upgrade-Insecure-Requests: 1
Cookie: _session_id=xxxxx; remember_user_token=xxx; Hm_lpvt_0c0e9d9b1e7d617b3e6842e85b9fb068=1493626002; Hm_lvt_0c0e9d9b1e7d617b3e6842e85b9fb068=1493550585,1493622639,1493623143,1493625980; _ga=GA1.2.487162296.1493344586; _gat=1
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/10.1 Safari/603.1.30
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
Connection: keep-alive
请求头由一些键值对组成,每个键值对的形式为:Key:空格Value+CRLF
,需要强调的是,最后一个键值对结束后再跟一个CRLF,就表示header结束了。
HTTP本身定义了一些header key,(需要了解各个key的含义,看请求头响应头参考表)另外也允许开发者添加自己的key,自定义的key一般以X开头,比如可以定义X-APP-VERSION来记录客户端的版本号。
- 请求体Body
body里面包含请求的实际数据。
Method=GET,body可以不存在,header最后的两个CRLF就标识着请求的结尾。请求的业务参数通过request line中的URI中的query string来传递,如UIR: /p/q81RER?t=aa&t1=bb,query string部分t=aa&t1=bb体现了业务参数,这部分也同样是以键值对的形式存在的。
Method=POST,body体一般不为空,我们实际的业务数据都存放于body当中,数据在body体中是以何种形式存在,其实大有门道,后面再细说。至于Request-URI当中的query string部分,我们依然可以选择放置一部分数据在其中,但更普遍的做法是使用body体。
3.http响应(Response)内容
如图所示,response的结构和request的结构几乎一样,只不过是Request Line变成了Status Line。
下面是一个完整的response内容例子:
HTTP/1.1 200 OK
Date: Mon, 01 May 2017 08:07:01 GMT
Server: Tengine
Content-Type: application/json; charset=utf-8
X-Frame-Options: DENY
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
ETag: W/"8736cdfe08480bca66cffeee06268705"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _session_id=xxxxx; path=/; HttpOnly
X-Request-Id: e7a4211c-efde-4e87-9a48-1e6f09de5afd
X-Runtime: 0.038405
Content-Encoding: gzip
X-Via: 1.1 tongyidong11:0 (Cdn Cache Server V2.0)
Transfer-Encoding: chunked
Proxy-Connection: Keep-alive
{"message":"success"}