概述

HTTP协议以明文方式发送内容,不提供任何方式的数据加密。HTTP + TLS/SSL = HTTPS,是以安全为目标的HTTP通道。TLS (Transport Layer Security)是传输层加密协议,它的前身是 SSL 协议。

TLS 协议如何保证安全

1
2
3
1,	内容加密。
2, 身份认证。
3, 数据完整性。

TLS加密方式

  • 对称加密
    加密强度较高
    无法安全的保管密钥
    常见算法:DES、3DES、Blowfish、
    IDEA、RC4、RC5、RC6和AES
  • 非对称加密
    比对称加密更安全
    CPU消耗大
    加密长度有限制,不可超过公钥长度
    常见算法: RSA / ECDHE / DH / DHE

HTTPS的优点

  • 使用HTTPS协议可认证用户和服务器,确保数据发送到正确的客户机和服务器;
  • HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,要比http协议安全,可防止数据在传输过程中不被窃取、改变,确保数据的完整性。
  • HTTPS是现行架构下最安全的解决方案,虽然不是绝对安全,但它大幅增加了中间人攻击的成本。

HTTPS的缺点

  • HTTPS协议握手阶段比较费时,会使页面的加载时间延长近50%,增加10%到20%的耗电;
  • HTTPS连接缓存不如HTTP高效,会增加数据开销和功耗,甚至已有的安全措施也会因此而受到影响;
  • SSL证书需要钱,功能越强大的证书费用越高,个人网站、小网站没有必要一般不会用。
  • SSL证书通常需要绑定IP,不能在同一IP上绑定多个域名,IPv4资源不可能支撑这个消耗。
  • HTTPS协议的加密范围也比较有限,在黑客攻击、拒绝服务攻击、服务器劫持等方面几乎起不到什么作用。最关键的,SSL证书的信用链体系并不安全,特别是在某些国家可以控制CA根证书的情况下,中间人攻击一样可行。