http/1.0/1.1/2.0与https的比较
HTTP是HyperText Transfer Protocol的缩写,译为超文本传输协议。是一种应用于OSI七层模型中应用层的协议,是我们平常互联网网络通信传输的基础。它的作用就是规定了服务器和客户端之间的建立连接,请求数据,响应数据,关闭连接(我们常说的三次握手,四次挥手)。
建立连接阶段:进行三次握手:1.客户端向服务端发送连接请求,2.服务端回应客户端:ok,已经确认,3,客户端回应服务端,收到你的确认信息。
进行请求阶段:以下图为例,浏览器对于服务器的请求,浏览器会将我们对于服务器的请求封装成请求头和请求体。请求头包括浏览器的类型,请求的域名,ip地址,请求的方法类型等,请求体可以是参数形式,如 ?page=3&offset=3,也可以是post请求的哈希数据或者json。每个请求头用\r\n隔开,请求头请求体用\r\n\r\n隔开,这是HTTP规定好的格式。


服务器响应:服务器接收到客户端传来的请求头请求体后,分解进行回应,首先以状态码开头,经常见到的404以及302这样的信息,接着浏览器接收到html信息就渲染成了我们所见到的页面。

关闭阶段:四次挥手:客户端发送关闭连接请求,服务端回复:收到请求,准备关闭,服务端回复:可以断开了,客户端:收到,确认!
HTTP/1.0 规定浏览器与服务器之保持短暂的连接,浏览器的每次请求都需要与服务器建立一个TCP连接,服务器完成请求处理后立即断开TCP连接,服务器不追踪每个浏览器也不记录每个浏览器的请求。因为TCP请求是无状态的,所以每次都需要完成三次握手四次挥手,数据量一多,就非常浪费时间,效率比较低。
对于HTTP/1.0版本,1.1版本对这一点做了改进:
引入了管道机制:TCP连接建立后,不马上断开连接,而是过一会,如果没有收到客户端请求后,再断开连接。
这样做的好处有两点:1.不需要多次的三次握手四次挥手,提高了效率,2.因为一个服务器是被多个客户端同时访问的,一些信息如果客户端强制结束可能会发到其他的客户端,造成错误,如果可以延时关闭,可以给服务器充分的时间确认连接状态以及发送关闭信号。
HTTP2是HTTP/1.1的升级,客户端TCP连接只能一次一次的发送,为了提升效率,HTTP2引入了多路复用,就是可以客户端一次发送多个请求,服务端一起回复,提升了效率。但由于在信息的封装上还不够成熟,技术成本比较高,已受到攻击,目前普及度不高。

HTTPS 是HyperText Transfer Protocol Secure缩写,相较于HTTP,突出了安全!因为在网络信息传输过程中服务端和客户端的信息都会被SSL,TSL加密,在传输的过程中,即便被截取了,别人也不知道你们的会话内容是什么,只有收发方才有对应的密钥去解开,再对内容进行回应。其中的原理就是:服务端和客户端都有两把钥匙:公钥和私钥,公钥用来加密数据,同时只能用自己的私钥去解开,这样及时公钥被截获,密文内容也破解不了。
私钥使用非对称的方式生成的,关于非对称加密有兴趣的老板可以自行搜索一下,实现的过程就是:
1.服务器发送公钥信息给服务器,2.这个公钥是经过第三方认证加密的有数字证书,无法造假的,3.浏览器接收到公钥,根据算法生成私钥,再把私钥加密返回给服务器,4服务器解析私钥,这样就有了共同的私钥了。目前大部分网站都是采用这种协议了,不过https每年的价格也是不菲呢,大企业的证书年费用上十万都是正常的。

http/1.0/1.1/2.0与https的比较的更多相关文章
- js正则表达式校验非负浮点数:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- [转]IIS6.0迁移至IIS7.0
原文地址:http://www.splaybow.com/post/iis-6.0-7.0.html 公司的项目需要迁移到IIS7的目标机器中 在此做记录 原来server 2003系统 迁到2008 ...
- 编译可在Nexus5上运行的CyanogenMod13.0 ROM(基于Android6.0)
编译可在Nexus5上运行的CyanogenMod13.0 ROM (基于Android6.0) 作者:寻禹@阿里聚安全 前言 下文中无特殊说明时CM代表CyanogenMod的缩写. 下文中说的“设 ...
- iis7.0上发布mvc4.0网站
步骤如下: 1.右击需要发布的项目,在弹出的菜单中选择“发布...”选项 2.在“发布web”对话框中进行设置,配置文件名称默认为“配置文件1”可以修改为需要的名字,以便识别,也可以不改.发布方法选择 ...
- IIS6.0添加上.net4.0后,以前的.net系统出现“服务器应用程序不可用”的错误提示解决办法
把VS2010开发的网站.net4.0部署到Windows Server 2003的服务器上去, Windows Server 2003操作系统自带的为IIS 6.0,IIS 6.0一般只支持.NET ...
- Swift 3.0 【Swift 3.0 相较于 Swift 2.2 的变化】
一.编译器和语法变化 函数或方法参数 调用函数或方法时从第一个参数开始就必须指定参数名 在Swift的历史版本中出现过在调用函数时不需要指定任何函数参数(或者从第二个参数开始指定参数名),在调用方法时 ...
- 给定一个double类型的数组arr,其中的元素可正可负可0,返回子数组累乘的最大乘积。例如arr=[-2.5,4,0,3,0.5,8,-1],子数组[3,0.5,8]累乘可以获得最大的乘积12,所以返回12。
分析,是一个dp的题目, 设f[i]表示以i为结尾的最大值,g[i]表示以i结尾的最小值,那么 f[i+1] = max{f[i]*arr[i+1], g[i]*arr[i+1],arr[i+1]} ...
- Elasticsearch5.0.1 + Kibana5.0.1 + IK 5.0.1安装记录
最近工作需要,开始研究ES,当前ES的最新版本为5.0.1,从之前的2.x的版本号一下升级到5.x,主要是之前Elastic的产品版本号因为收购等原因很乱,ES 2.X版本的和Kibana 4.x版本 ...
- Oracle_RAC数据库GI的PSU升级(11.2.0.4.0到11.2.0.4.8)
Oracle_RAC数据库GI的PSU升级(11.2.0.4.0到11.2.0.4.8) 本次演示为升级oracle rac数据库,用GI的psu升级,从11.2.0.4.0升级到11.2.0.4.8 ...
- elasticsearch5.0集群+kibana5.0+head插件插件的安装
elasticsearch5.0集群+kibana5.0+head插件插件的安装 es集群的规划: 两台16核64G内存的服务器: yunva_etl_es1 ip:1.1.1.1 u04es01. ...
随机推荐
- 02:安装 Kerberos
1.1 环境介绍 参考博客:https://www.cnblogs.com/xiaodf/p/5968178.html https://www.douban.com/note/701660289/ ...
- No bean named 'dataSource' is defined
jar包导入多了,导jar包只需引用一次,如果dao层引用了pojo,然后service只需引用dao就可以引用pojo,然后重新maven install 就好了 如果删除导入多余的jar包不行, ...
- Android5.0新特性之——控件移动动画(初级)
最近开发,UI大牛们设计了好多很炫酷吊炸天的动画,不由得重新学习了一下5.0的ObjectAnimator动画. ObjectAnimator动画的原理,通过反射控件的setXXX方法,改变控件的实际 ...
- mybatis逆向工程失败
[ERROR] Failed to execute goal org.mybatis.generator:mybatis-generator-maven-plugin:1.3.6:generate ( ...
- video 自动循环播放
video 只加autoplay并不能自动播放,需要再加上muted <video controls="controls" autoplay loop muted> ...
- Linux源码包安装程序
★安装OS时,建议提前安装开发组件 CentOS 6:Development Tools.Server Platform DevelopmentCentOS 7:Development Tools.D ...
- jmeter的安装和配置
jmeter环境配置 Java 8 安装 正常安装,一路默认就好,记住安装路径,配置环境变量时用得到.默认安装路径:C:\Program Files\Java\jdk1.8.0_91. 安装好之后会有 ...
- 集合基本操作 Python DAY2
集合本身具有两个特性 1.去重 2.关系测试 列表转集合的两种写法: list_1=[1,2,3,4,1,2,7,8,] list_1=set(list_1) #方法二 list_2=set([1, ...
- (详细)华为V9 DUK-AL20的usb调试模式在哪里打开的方法
当我们使用PC通过数据线链接到安卓手机的时候,如果手机没有开启USB开发者调试模式,PC则没办法成功识别我们的手机,有时我们使用的一些功能较好的软件好比以前我们使用的一个软件引号精灵,老版本就需要打开 ...
- Linux之nginx入门
nginx入门 详见可参考:https://www.cnblogs.com/tiger666/p/10239307.html?tdsourcetag=s_pctim_aiomsg 1. 常用的WEB框 ...