zoukankan
html css js c++ java
HTTP
图解HTTP
在2D平面上行走的时候,认识只局限于“点”,刚认识一个新的点,就把之前的那个点忘记了,捡了芝麻丢西瓜。只从3D视角俯瞰时,把这些点连接在一起,点成线,线成面时,才能有所顿悟。话不多说,这是我对HTTP的不完全图解。希望对大家整体上初步理解HTTP有所帮助。
整体上来看,HTTP分为五个部分。
1.报文
报文 = 报文首部 + 报文主体
打上了“红旗”的,代表非常重要:
(1)首部字段
(2)Cookie 和 Set-Cookie
Cookie:客户端告知服务器想获得HTTP状态管理支持。
Set-Cookie: 服务器管理客户端的状态。
1.1 请求报文
1.2 响应报文
2. 通信传输
这里需要问自己这样的问题:
(1)为什么会有“分层”这个概念?
(2)三次握手的过程?如果中断了怎么办?
发送端将一个带SYN标志的数据包给接收端。
接收端回传一个带有SYN/ACK标志的数据包,传达确认信息。
发送端回传一个带ACK标志的数据包,代表“握手”结束。
如果中断,TCP协议会再次以相同的顺序发送相同的数据包。
3.服务器
这里重点理解一下缓存策略。
第一阶段--本地缓存。
第二阶段:缓存协商。在这个阶段,需要用到两组首部字段Last-Modified/IF-Modified-Since和Etag/If-None-Match。
4.优化
5.安全
这部分需要理解为什么会出现HTTPS,HTTPS中的SSL是什么,HTTPS的利弊。
基于表单认证部分需要联系一下第一部分报文中的Cookie和Set-Cookie:
(1)客户端发送用户ID、密码
(2)服务器向用户发放Session ID,记录用户状态(Set-Cookie)
(2)客户端接收Session ID,并将其作为Cookie保存在本地。
(4)下次向服务器发送请求时,浏览器会自动发送Cookie
(5)服务器端可验证收到的Session ID来识别用户
回顾一下,总体上大概就是这样的。安利一下XMind,用来画思维导图,非常赞。祝大家五一快乐。
标签:
不完全图解
,
前端
查看全文
相关阅读:
[译]CasperJS,基于PhantomJS的工具包
[译]JavaScript:typeof的用途
[译]JavaScript写的一个quine程序
[译]Ruby中的解构赋值
[译]DOM:元素ID就是全局变量
[译]ECMAScript 6中的集合类型,第一部分:Set
[译]JavaScript:Array.prototype和[]的性能差异
[译]Web Inspector开始支持CSS区域
[译]JavaScript:反科里化"this"
[译]JavaScript:用什么来缩进
原文地址:https://www.cnblogs.com/Leo_wl/p/6798382.html
最新文章
[译]JavaScript:参数中的数组展开
[译]JavaScript:运算符
[译]JavaScript:什么时候能用==
[译]Apply和数组:三个技巧
[译]JavaScript中,什么对象不是Object的实例?
[译]XPath和CSS选择器
[译]ECMAScript 6中的集合类型,第二部分:Map
[译]"空"正则
[译]从CoffeeScript转到LiveScript的10个理由
[译]JavaScript中,{}+{}等于多少?
热门文章
[译]ECMAScript:ES.next和ES6以及ES Harmony之间的区别
[译]JavaScript:void运算符
[译]JavaScript:用Node.js写Shell脚本
[译]JavaScript中:表达式和语句的区别
[译]JavaScript:"更"严格的相等
[译]JavaScript:打破所有规则
[译]JavaScript中,如何将一个值转换为字符串
[译]ECMAScript 6相关资源收集
[译]Array.prototype.concat不是通用方法
ECMA TC39技术委员会成员
Copyright © 2011-2022 走看看