说一下http和https
https的SSL加密是在传输层实现的。
http
超文本传输协议
,是互联网上应用最为广泛的一种网络协议,是一个客户端
和服务器端
请求和应答的标准(TCP),用于从WWW服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少。
https
是以安全为目标的HTTP通道,简单讲是HTTP的安全版,即HTTP下加入SSL
层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。HTTPS主要作用是建立一个信息安全通道,来确保数组的传输,确保网站的真实性。
http与https的区别
http :
- http传输的数据都是
未加密
的,也就是明文传输
的 - http协议的端口默认为
80
- http的连接是
无状态
的
https :
- https协议是由http和ssl协议构建的可进行
加密传输
和身份认证
的网络协议 - https协议的
安全性更高
- https协议
需要ca证书
,费用较高 - https传输的数据是
ssl加密传输
- https协议的端口默认为
443
https协议的工作原理
客户端
使用httpsurl访问服务器
,则要求web服务器建立ssl链接
web服务器
接收到客户端的请求之后,会将网站的证书
(证书中包含了公钥),返回
或者说传输给客户端
- 客户端和web服务器端开始协商SSl链接的安全等级,也就是加密等级
客户端浏览器
通过双方协议一致的安全等级,建立会话密钥
,然后通过网站的公钥来加密会话密钥
,并传送给网站
- web服务器通过自己的私钥
解密
出会话密钥
- web服务器通过会话密钥加密与
客户端
之间的通信
https协议的优点
- 使用HTTPS协议可认证用户和服务器,确保数据发送到正确的客户机和服务器
- HTTPS协议是由SSL+HTTP协议构建的可进行
加密传输
、身份认证
的网络协议,要比http协议安全
,可防止数据在传输过程中不被窃取、改变,确保数据的完整性
。 - 更有利于
SEO
。
https协议的缺点
- https握手阶段
比较费时
,会使页面加载时间延长50%,增加10%~20%的耗电。 - https缓存不如http高效,会
增加数据开销
。 - SSL证书也需要钱,功能越强大的证书
费用越高
。 - SSL证书需要绑定IP,
不能再同一个ip上绑定多个域名
,ipv4资源支持不了这种消耗。
说一下http2.0
http2.0是基于1999年发布的http1.0之后的首次更新。
提升访问速度
(可以对于,请求资源所需时间更少,访问速度更快,相比http1.0)允许多路复用
:多路复用允许同时通过单一的HTTP/2连接发送多重请求-响应信息。改善了:在http1.1中,浏览器客户端在同一时间,针对同一域名下的请求有一定数量限制(连接数量),超过限制会被阻塞。二进制分帧
:HTTP2.0会将所有的传输信息分割为更小的信息或者帧,并对他们进行二进制编码首部压缩
服务器端推送