zoukankan      html  css  js  c++  java
  • [Java] 绕过证书验证调 HTTPS 接口时报 “SSLHandshakeException: DHPublicKey does not comply to algorithm constraints”的解决办法

    作者: zyl910

    一、缘由

    最近有在对接一个无证书的HTTPS接口时,总是收到“SSLHandshakeException: DHPublicKey does not comply to algorithm constraints”异常。
    通过浏览器、telnet测试了接口地址,确认了TCP层是通的。看来只是HTTPS层没通。
    可是试验了好几个网上找到的“绕过证书验证调HTTPS接口”的办法,均也报这个错误,无法调通接口。

    后来问了很多人,才终于找到处理办法。便将经验分享给大家。

    二、处理办法

    打开 JDK 目录下的 jrelibsecurityjava.security 文件。例如 C:Javajdk1.7.0_45jrelibsecurityjava.security

    在文件中找到 jdk.certpath.disabledAlgorithmsjdk.tls.disabledAlgorithms 这两个参数。例如——

    jdk.certpath.disabledAlgorithms=MD2, MD5, SHA1 jdkCA & usage TLSServer, 
        RSA keySize < 1024, DSA keySize < 1024, EC keySize < 224
    jdk.tls.disabledAlgorithms=SSLv3, RC4, MD5withRSA, DH keySize < 1024, 
        EC keySize < 224, DES40_CBC, RC4_40
    

    然后将这2个参数改为以下值,并保存。

    jdk.certpath.disabledAlgorithms=MD2, RSA keySize < 1024
    jdk.tls.disabledAlgorithms=SSLv3, RC4, DH keySize < 268
    

    这样便能调用了。

    参考文献

  • 相关阅读:
    JSON Web Token
    Centos 7下编译安装PHP7.2(与Nginx搭配的安装方式)
    Nginx配置详解
    Centos 7下编译安装Nginx
    PHP常用正则验证
    拼手气红包函数
    获取汉字首字母大写
    根据生日计算年龄
    ffmpeg获取视频封面图片
    对象脑图总结
  • 原文地址:https://www.cnblogs.com/zyl910/p/java_https_SSLHandshakeException.html
Copyright © 2011-2022 走看看