基础课堂协议Java技术升华

HTTP协议(二):HTTPS

2018-09-26  本文已影响497人  小小的白菜

HTTPS 协议(HyperText Transfer Protocol over Secure Socket Layer):可以理解为HTTP+SSL/TLS, 即 HTTP下加入 SSL 层,HTTPS的安全基础是 SSL,因此加密的详细内容就需要 SSL,用于安全的 HTTP 数据传输。

HTTPS和HTTP的区别

HTTP的不足

SSL

SSLSecure Socket Layer,安全套接字层):1994年为 Netscape 所研发,SSL 协议位于 TCP/IP协议与各种应用层协议之间,为数据通讯提供安全支持。

TLS

TLSTransport Layer Security):其前身是SSL,它最初的几个版本(SSL 1.0SSL 2.0SSL 3.0)由网景公司开发,1999年从 3.1开始被IETF 标准化并改名,发展至今已经有 TLS 1.0TLS 1.1TLS 1.2 三个版本。SSL3.0TLS1.0由于存在安全漏洞,已经很少被使用到。TLS 1.3改动会比较大,目前还在草案阶段,目前使用最广泛的是TLS 1.1TLS 1.2

加密算法

对称加密

对称加密算法非常简单,只要加密方和解密方都拥有同一密钥(可为128192256 bit大小的密钥,密钥越长,加密解密时间越长,解密难度也越高),即可完成加密解密过程,且假设无法强制对加密过的明文进行解密。

非对称加密

加密使用的密钥和解密使用的密钥是不相同的,分别称为:公钥、私钥,公钥和算法都是公开的,私钥是保密的。非对称加密算法性能较低,但是安全性超强,由于其加密特性,非对称加密算法能加密的数据长度也是有限的。例如:RSADSAECDSADHECDHE

哈希算法

将任意长度的信息转换为较短的固定长度的值,通常其长度要比信息小得多,且算法不可逆。例如:MD5SHA-1SHA-2SHA-256 等。

数字签名

签名就是在信息的后面再加上一段内容(信息经过hash后的值),可以证明信息没有被修改过。hash值一般都会加密后(也就是签名)再和信息一起发送,以保证这个hash值不被修改。

HTTP 向 HTTPS 演化的过程

第一步:对传输的信息加密

对称加密

此种方式属于对称加密,双方拥有相同的密钥,信息得到安全传输,但此种方式的缺点是:

第二步:非对称加密

非对称性加密

客户端用公钥对请求内容加密,服务器使用私钥对内容解密,反之亦然,但上述过程也存在缺点:

第三步:对称加密,非对称加密两者结合

对称加密,非对称加密两者结合
遇到的问题

第四步:获取公钥与确认服务器身份

设想
SSL 证书
SSL
浏览器认证

客户端在接受到服务端发来的SSL证书时,会对证书的真伪进行校验,以浏览器为例说明如下

HTTPS 缺点:

HTTPS 的工作流程

客户端在使用HTTPS方式与Web服务器通信时有以下几个步骤:

HTTPS 的工作流程

参考文章

【HTTP】HTTPS 原理详解
看图学HTTPS
HTTPS 的故事
白话https
手把手HTTPS

上一篇 下一篇

猜你喜欢

热点阅读