http协议:超文本传输协议
客户端的浏览器首先要通过网络与服务器建立连接,该连接是通过TCP来完成的,一般TCP连接的端口号是80,
HTTP协议是以明文方式发送信息的,如果黑客截取了Web浏览器和服务器之间的传输报文,就可以直接获得其中的信息,所以不安全
https协议:
是以安全为目标的HTTP通道,是HTTP的安全版。HTTPS的安全基础是SSL。SSL协议位于TCP/IP协议与各种应用层协议之间,为数据通讯提供安全支持。
SSL协议可分为两层:SSL记录协议(SSL Record Protocol),它建立在可靠的传输协议(如TCP)之上,为高层协议提供数据封装、压缩、加密等基本功能的支持。
SSL握手协议(SSL Handshake Protocol),它建立在SSL记录协议之上,用于在实际的数据传输开始前,通讯双方进行身份认证、协商加密算法、交换加密密钥等
优点:
-
使用HTTPS协议可认证用户和服务器,确保数据发送到正确的客户机和服务器。
-
HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比HTTP协议安全,可防止数据在传输过程中不被窃取、修改,确保数据的完整性。
-
HTTPS是现行架构下最安全的解决方案,虽然不是绝对安全,但它大幅增加了中间人攻击的成本。
缺点:
-
HTTPS协议握手阶段比较费时,会使页面的加载时间延长近50%,增加10%到20%的耗电。
-
HTTPS连接缓存不如HTTP高效,会增加数据开销,甚至已有的安全措施也会因此而受到影响。
-
HTTPS协议的安全是有范围的,在黑客攻击、拒绝服务攻击和服务器劫持等方面几乎起不到什么作用。
-
SSL证书通常需要绑定IP,不能在同一IP上绑定多个域名,IPv4资源不可能支撑这个消耗。
-
功能越强大的SSL成本越高。部署HTTPS后,因为HTTPS协议的工作要增加额外的计算资源消耗,例如SSL协议加密算法和SSL交互次数将占用一定的计算资源和服务器成本。
-
HTTPS协议的加密范围也比较有限。在黑客攻击、拒绝服务攻击、服务器劫持等方面几乎起不到什么作用。最关键的是SSL证书的信用链体系并不安全,特别是在某些国家可以控制CA根证书的情况下,中间人攻击一样可行。
HTTP和HTTPS的区别
HTTPS协议需要到CA(Certificate Authority,证书颁发机构)申请证书,不过一般免费证书较少,因而需要一定费用。
HTTP是超文本传输协议,信息是明文传输,而HTTPS则是具有安全性的SSL/TLS加密传输协议。
HTTP和HTTPS使用的是完全不同的连接方式,用的端口也不一样,HTTP是80,HTTPS是443。
HTTP的连接很简单,是无状态的(无状态的意思是其数据包的发送、传输和接收都是相互独立的。无连接的意思是指通信双方都不长久的维持对方的任何信息。)。
HTTPS协议是由 SSL/TLS+HTTP协议构建的可进行加密传输、身份认证的网络协议,比 HTTP 协议安全。
总结:
-
保证数据完整性:内容传输经过完整性校验,防止传输的内容被中间人冒充或者篡改;
-
数据隐私性:内容经过对称加密,每个连接生成一个唯一的加密密钥,中间者无法直接查看明文内容;
-
身份认证:通过证书认证客户端访问的是自己的;服务器,第三方无法伪造服务端(客户端)身份