Https握手失败问题

作者: maisie0731 | 来源:发表于2016-08-04 17:21 被阅读3121次

遇到的问题

昨天遇到一个问题,Https请求握手失败的问题,报SSLHandShakeException。一开始不明白,以为是特定网络的问题,但经同事指点,应该是证书校验的问题。查询证书有效性,验证证书确实有效,那么问题究竟是什么?
后发现是访问的网络采用代理导致,代理服务器的证书无效,虽然原网站的证书 有效,但经过代理控制访问后,客户端验证代理的证书无效,所以导致证书校验失败。

Https请求的过程

梳理了Https的请求过程


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

答案

回过来看我们的问题,有两种可能:

  • 代理服务器在证书校验的过程中被校验为无效的证书,所以没有办法完成后续的流程,抛出了SSLHandShankException。
  • 代理服务器的公钥和私钥与原服务器公钥和私钥不同,在客户端用key加密的握手信息传给服务器端校验时因为采用了代理服务器的公钥来进行的加密,所以,服务器用自己的私钥解密失败,导致握手失败。

相关文章

  • Https握手失败问题

    遇到的问题 昨天遇到一个问题,Https请求握手失败的问题,报SSLHandShakeException。一开始不...

  • Moya,KingFisher中使用自签名证书发起HTTPS请求

    Moya信任自签名证书 问题 先说说HTTPS握手, 发送HTTPS请求首先要进行SSL/TLS握手,握手过程大致...

  • https 握手

    https 通讯是用SSL/TLS加密的http 通讯 使用HTTPS通讯的好处是什么勒 1 所有的信息都是加密传...

  • HTTPS握手

    1. 客户端先发出请求 首先,客户端(通常是浏览器)先向服务器发出加密通信需求,这加clientHello请求。在...

  • https握手

    HTTPS SSL握手过程 图解SSL/TLS协议ssl握手过程 用户发起一个请求到服务器,浏览器将自己支持的一套...

  • HTTPS握手失败的案例之SNI

    问题背景: 在听云测试业务,发现很多安全频道出错,分析失败的点,大部分位于听云一个检测点,检测的浏览器是ie8,分...

  • SSL IBM JDK握手失败 报No trusted cert

    前几天解决了一个SSL握手失败问题,避免了一场史诗级生产事故,如果在IBM JDK握手失败,而Oracle JDK...

  • Moya,KingFisher中使用自签名证书发起HTTPS请求

    HTTPS握手 先说声https握手,发送 HTTPS 请求首先要进行 SSL/TLS 握手,握手过程大致如下: ...

  • Glide 加载https 失败问题

    后端临时替换证书,当时紧急上线,在阿里云买了一个不是很正规的证书,可以马上审核通过。替换完证书后,所有图片相关都加...

  • HTTPS与握手

    HTTPS (HyperText Transfer Protocol over Secure Socket Lay...

网友评论

    本文标题:Https握手失败问题

    本文链接:https://www.haomeiwen.com/subject/bgmxsttx.html