https的握手过程简聊

 https在传输数据之前需要在客户端(浏览器)与服务端(网站)之间进行一次握手,在握手过程中将确立双方加密传输数据的密码信息。

使用的是TLS/SSL协议。

握手过程的简单描述如下:

1、浏览器首先将自己的一套加密规则发送给网站。

2、网站从中选出一组加密算法与hash算法,加密算法用来加密数据,哈希算法用来验证数据的完整性。并将自己的信息以证书的形式发送给浏览器(网站的url,证书颁布机构,加密公钥等)。

3、浏览器拿到证书后

首先验证证书的合法性( 证书中的url与当前网站的url是否一致,证书颁布机构是否合法),如果证书受信任,这浏览器会出现一个小锁的标志。

其次如果证书受信任,或者是用户接受了不受信任的证书,浏览器会生成一段随机数作为密码,并用证书中的公钥进行加密。

最后使用约定好的hash算法计算握手消息,并用随机生成的随机数对消息进行加密,最后将之前生成的所有信息发送给网站。

4、网站拿到信息后,

首先使用自己的私钥,对密码进行解密,然后根据解密的密码对握手信息进行解密,并验证哈西是否与浏览器发来的一致。

然后使用密码加密一段,握手消息发送给浏览器。

5、如果浏览器解密并计算握手信息的哈希与网站发来的哈希一致,此时握手过程结束,之后所有的通信数据将使用之前浏览器生成的随机密码,并利用对称加密算法进行加密。

 

非对称加密算法:rsa,dsa/dss

对称加密算法:aes,rc4,3des

哈希算法:md5,sha1,sha256

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山楂橙子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值