1 HTTP网络协议栈
HTTP协议通常承载于TCP协议之上,有时也承载于TLS或SSL协议层之上,这时候就成了HTTPS。
默认HTTP的端口号为80,HTTPS的端口号为443。
2 HTTP报文结构
http有两类报文:请求报文 响应报文。
整体结构:
起始行
报文头
空行
报文数据
2.1 请求报文(Request)
请求行:Method url version
消息报头:Headers
空行:回车符换行符
请求正文:Body
2.2 响应报文(Response)
状态行:Version status reason
消息报头:Headers
空行:回车符换行符
响应正文:Body
2.3 消息报头(首部)
2.3.1 通用首部(请求/响应)
Connection:close|keep-alive
Date:日期时间
Host:请求的主机
Pragma: no-cache在HTTP/1.1协议中,和Cache- Control:no-cache含义相同。Pragma用来包含实现特定的指令。
Via:请求或响应在客户端和服务器之间传递时经过的代理
Transfer-Encoding:消息主题的传输编码方式,chunked表示采用块编码的方式
2.3.2 请求报头
If-Modified-Since:请求的资源在某个时间后是否有修改
If-None-Match:条件式请求首部,仅当服务器上没有任何资源的ETag值与这个首部的相匹配,服务器才会返回请求的资源,响应200
Referer:当前请求的来源
User-Agent:代理
Host:请求的主机
Accept-Encoding:接受的编码方式
Accept-Language:接受的自然语言
Accept-Charset:接受字符集
Authorization:服务器端发送www-authenticate时,客户端通过此首部提供认证信息
2.3.3 响应报头
ETag:内容的标签
Location:重定向后的新位置
Server:服务器软件信息
WWW-Authenticate:要求对客户端进行认证
Age:当代理服务器用自己缓存的实体去响应请求时,该头部表明该实体从产生到现在经过多长时间了
2.3.4 实体报头
请求和响应消息都可以传送一个实体。一个实体由实体报头域和实体正文组成。实体报头定义了关于实体正文和请求所标识的资源的元信息。
Content-Encoding:内容的编码
Content-Language:表示报文体使用的语言,如ch,fr,en,ja等
Content-Lenth:内容的长度
Content-Type:内容的MIME格式
Expires:浏览器依据该过期日期与客户端时间对比,如果过期时间没到,则会去缓存中读取该资源;如果已经到期,重新从服务端获取.
Last-Modified:最近一次的修改时间
3 HTTP请求报文示例
GET /Article/Index/02/02/1.html HTTP/1.1
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Accept-Encoding:gzip, deflate
Accept-Language:zh-CN,zh;q=0.9
Cache-Control:max-age=0
Cookie:UM_distinctid=163e3e32f4917c-0e75f370b7422d-5e4a2e19-e1000-163e3e32f4b16b; __RequestVerificationToken=m7k2Xu9k0QRYhBPIz3Xh4b2SElGparYNzJ26Mz8MFREkftWq64-cs3vFKzVn803w82Rb-zxJhSu44FN4iyO9sQi2a5-3j-eTLML3sUSu1Wo1; ASP.NET_SessionId=rdh3cahyvbplyucju1it5lnk; CNZZDATA1253705588=1446599400-1528536705-%7C1529290896
Host:iprogram.com.cn
Proxy-Connection:keep-alive
Referer:http://iprogram.com.cn/ArticleMgr/Edit/211.html
Upgrade-Insecure-Requests:1
User-Agent:Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.87 Safari/537.36
4 HTTP响应报文示例
HTTP/1.1 200 OK
Cache-Control:private
Content-Length:41111
Content-Type:text/html; charset=utf-8
Date:Mon, 18 Jun 2018 03:13:53 GMT
Server:Microsoft-IIS/7.5
X-AspNet-Version:4.0.30319
X-AspNetMvc-Version:5.2
X-Powered-By:ASP.NET
(响应数据略)