[h2] 在2D平面上行走的时候,认识只局限于“点”,刚认识一个新的点,就把之前的那个点忘记了,捡了芝麻丢西瓜。只从3D视角俯瞰时,把这些点连接在一起,点成线,线成面时,才能有所顿悟。话不多说,这是我对HTTP的不完全图解。希望对大家整体上初步理解HTTP有所帮助。[/h2]
[h2] 整体上来看,HTTP分为五个部分。[/h2]
1.报文
[h3]报文 = 报文首部 + 报文主体[/h3]
[h3]打上了“红旗”的,代表非常重要:[/h3]
[h3](1)首部字段[/h3]
[h3](2)Cookie 和 Set-Cookie[/h3]
[h3]Cookie:客户端告知服务器想获得HTTP状态管理支持。[/h3]
[h3]Set-Cookie: 服务器管理客户端的状态。[/h3]
[h1]1.1 请求报文[/h1]
[h1]1.2 响应报文[/h1]
2. 通信传输
[h3]这里需要问自己这样的问题:[/h3]
[h3](1)为什么会有“分层”这个概念?[/h3]
[h3](2)三次握手的过程?如果中断了怎么办?[/h3]
[h3] 发送端将一个带SYN标志的数据包给接收端。
接收端回传一个带有SYN/ACK标志的数据包,传达确认信息。
发送端回传一个带ACK标志的数据包,代表“握手”结束。[/h3]
[h3] 如果中断,TCP协议会再次以相同的顺序发送相同的数据包。[/h3]
3.服务器
[h3]这里重点理解一下缓存策略。[/h3]
[h3]第一阶段–本地缓存。[/h3]
[h3]第二阶段:缓存协商。在这个阶段,需要用到两组首部字段Last-Modified/IF-Modified-Since和Etag/If-None-Match。[/h3]
4.优化
5.安全
[h3] 这部分需要理解为什么会出现HTTPS,HTTPS中的SSL是什么,HTTPS的利弊。[/h3]
[h3] 基于表单认证部分需要联系一下第一部分报文中的Cookie和Set-Cookie:[/h3]
[h3](1)客户端发送用户ID、密码 [/h3]
[h3](2)服务器向用户发放Session ID,记录用户状态(Set-Cookie)[/h3]
[h3](2)客户端接收Session ID,并将其作为Cookie保存在本地。[/h3]
[h3](4)下次向服务器发送请求时,浏览器会自动发送Cookie[/h3]
[h3](5)服务器端可验证收到的Session ID来识别用户[/h3]
[h3] [/h3]
[h1] 回顾一下,总体上大概就是这样的。安利一下XMind,用来画思维导图,非常赞。祝大家五一快乐。[/h1]
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/industrynews/255985.html