基本概念
HTTP:超文本传输协议
HTTPS:在HTTP下加入SSL协议,即安全版的HTTP
HTTPS的SSL加密是在传输层实现的
HTTPS协议的主要作用:建立一个信息安全通道,来确保数组的传输,确保网站的真实性。
区别
HTTP传输的数据都是未经加密的,也就是明文传输。
HTTPS协议是由http和ssl协议构建的可进行加密传输和身份认证的网络协议,比http协议的安全性更高。
主要区别
- HTTPS协议需要CA证书,费用较高
- HTTP是超文本传输协议,信息是明文传输,HTTPS则是具有安全性的SSL加密传输协议
- 使用的链接不同,端口也不同,HTTP端口为80,HTTPS端口为443
- HTTP连接较快,HTTPS连接较慢
HTTPS协议的工作原理
客户端在使用HTTPS与Web服务器通信时有以下步骤
- 客户端使用https url访问服务器,则要求web服务器建立ssl连接
- web服务器收到客户端请求之后,会将网站的证书传输给客户端
- 客户端和服务器协商SSL连接的安全等级
- 通过双方确立的安全等级建立会话密钥,然后通过浏览器的公钥加密会话密钥,并传送给服务器
- web服务器通过自己的私钥解密出会话密钥
- web服务器通过会话密钥与客户端之间通信
对称加密与非对称加密
- 对称加密:加密的密钥和解密的密钥是一样的
- 非对称加密:加密的密钥和解密的密钥是不一致的,
非对称加密的速度比对称加密的速度要慢很多
HTTPS加密过程既用到了对称加密,也用到了非对称加密
- 通过“公钥加密,私钥解密”的方式传输密钥是非对称加密
- 通过加密密钥传输实际内容是对称加密
HTTP请求的方式,HEAD方式
- head:类似于get请求,只不过返回的响应中没有具体的内容,用户获取报头
- options:允许客户端查看服务器的性能,比如说服务器支持的请求方式等等。
HTTPS的优缺点
HTTPS协议的优点
- HTTPS可认证用户和服务器,确保数据发送到正确的客户端和服务器
- HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比http协议安全,可防止数据在传输过程中不被窃取、改变,确保数据的完整性。
- HTTPS是现行架构下最安全的解决方案,虽然不是绝对安全,但它大幅增加了中间人攻击的成本。
总的来说就是安全
HTTPS缺点
- https握手阶段比较费时,会使页面加载时间延长50%。
- https缓存不如http高效,会增加数据开销。
- SSL证书也需要钱,功能越强大的证书费用越高。
- SSL证书需要绑定IP,不能再同一个ip上绑定多个域名,ipv4资源支持不了这种消耗。
总的来说代价就是资源消耗高