大螃嗨

好记性不如烂笔头

用户工具

站点工具


https机制

这是本文档旧的修订版!


HTTPS机制

首先来表述一下HTTPS建立连接的过程:

  1. 浏览器将自己支持的一套加密规则发送给网站服务器。
  2. 网站从中选出一组加密算法与HASH算法,并将自己的身份信息以证书的形式发回给浏览器。证书里面包含了网站地址,加密公钥,以及证书的颁发机构等信息。
  3. 浏览器获得网站证书之后要做以下工作:
    1. 验证证书的合法性(颁发机构是否合法,证书中包含的网址是否与正在访问的地址一致等),如果证书受信任,浏览器地址栏会显示一个锁头标识,否则会给出证书不受信任的提示。
  4. 如果证书受信任,或者用户接受了不受信任的证书,浏览器会生成一串随机数的密码,并用证书中提供的公钥加密。
  5. 使用约定好的HASH算法计算握手消息,并使用生成的随机数对消息进行加密,最后将之前生成的所有信息发送给网站。
  6. 网站接收浏览器发来的数据之后要做以下的操作:
    1. 使用自己的私钥将信息解密取出密码,使用密码解密浏览器发来的握手消息,并验证HASH是否与浏览器发来的一致。
  7. 使用密码加密一段握手消息,发送给浏览器。
  8. 浏览器解密并计算握手消息的HASH,如果与服务器发来的HASH一致,此时握手过程结束,之后所有的通信数据将由之前浏览器生成的随机密码并利用对称加密算法进行加密。
https机制.1504603282.txt.gz · 最后更改: 2017/09/05 09:21 由 螃蟹