HTTP和HTTPS的区别

以下内容参考了豆豆蛙的博客:https://www.cnblogs.com/wqhwe/p/5407468.html

博主豆豆蛙分析的很全面很好。

HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协议传输隐私信息非常不安全,为了保证这些隐私数据能加密传输,于是网景公司设计了SSL(Secure Sockets Layer)协议用于对HTTP协议传输的数据进行加密,从而就诞生了HTTPS(Hypertext Transfer Protocol over Secure Socket Layer)。简单来说,HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比http协议安全。

 

HTTPS和HTTP的区别:

      1,https协议需要到ca申请证书,一般免费证书很少,需要交费。

      2,http是超文本传输协议,信息是明文传输,https 则是具有安全性的ssl加密传输协议。

      3,http和https使用的是完全不同的连接方式用的端口也不一样,前者是80,后者是443。

      4,http的连接很简单,是无状态的。

      5,HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比http协议安全

个人理解:

与HTTP相比,HTTPS就是如之前博客中介绍的非对称加密算法,客户端首先会向服务端发起请求,这时服务端会给客户端返回一个证书,证书里面包含产生的公钥,这时,客户端会随机产生对称密钥,然后用服务端返回的公钥对该密钥进行加密,再传输给服务端,服务端用本地的私钥进行解密,得到对称密钥。接下来,客户端和服务端就使用对称密钥进行通信了。

HTTPS的缺点:

HTTPS虽然不能说是绝对的安全,但是,起码增加了系统的复杂度,增加了黑客攻击的开销。此外,它还存在一定的缺点:

(1)HTTPS协议握手阶段比较费时,会使页面的加载时间延长近50%,增加10%到20%的耗电;

(2)HTTPS连接缓存不如HTTP高效,会增加数据开销和功耗,甚至已有的安全措施也会因此而受到影响;

(3)SSL证书需要钱,功能越强大的证书费用越高,个人网站、小网站没有必要一般不会用。

(4)SSL证书通常需要绑定IP,不能在同一IP上绑定多个域名,IPv4资源不可能支撑这个消耗。

(5)HTTPS协议的加密范围也比较有限,在黑客攻击、拒绝服务攻击、服务器劫持等方面几乎起不到什么作用。最关键的,SSL证书的信用链体系并不安全,特别是在某些国家可以控制CA根证书的情况下,中间人攻击一样可行。

 

你可能感兴趣的:(开发学习笔记(杂))