首页 >Java >java教程 >通过 HTTPS 访问 Web 服务时,如何修复'java.security.cert.CertificateException:不存在主题备用名称”错误?

通过 HTTPS 访问 Web 服务时,如何修复'java.security.cert.CertificateException:不存在主题备用名称”错误?

Linda Hamilton
Linda Hamilton原创
2024-11-08 02:31:02373浏览

How do I fix the

修复“java.security.cert.CertificateException:不存在主题备用名称”错误

使用以下命令通过 HTTPS 访问 Web 服务时Java 客户端遇到“java.security.cert.CertificateException:不存在主题备用名称”错误表示证书的主题名称与主机地址不匹配。

要解决此问题,请按照以下步骤操作:

  1. 从“openssl s_client”的输出中提取“-----BEGIN CERTIFICATE-----”和“-----END CERTIFICATE-----”之间的证书信息-showcerts -connect AAA.BBB.CCC.DDD:9443 -gt; certs.txt".
  2. 修改提取的证书,使“主题的通用名称 (CN)”字段与 IP 地址 (AAA. BBB.CCC.DDD)。这可以使用 OpenSSL 的“x509”命令等工具来实现。
  3. 使用“keytool -importcert -file fileWithModifiedCertificate”导入修改后的证书。

但是,此方法可能并不总是有效如果您无法控制服务器的证书,则可行。

另一种解决方案是禁用 HTTPS 检查。此方法涉及创建允许接受所有证书的自定义信任管理器和主机名验证器。在“ISomeService”类中,添加以下代码:

static {
    disableSslVerification();
}

private static void disableSslVerification() {
    // Create a trust manager that does not validate certificate chains
    TrustManager[] trustAllCerts = new TrustManager[] {new X509TrustManager() {
        public java.security.cert.X509Certificate[] getAcceptedIssuers() {
            return null;
        }
        public void checkClientTrusted(X509Certificate[] certs, String authType) {
        }
        public void checkServerTrusted(X509Certificate[] certs, String authType) {
        }
    }
    };

    // Install the all-trusting trust manager
    SSLContext sc = SSLContext.getInstance("SSL");
    sc.init(null, trustAllCerts, new java.security.SecureRandom());
    HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

    // Create all-trusting host name verifier
    HostnameVerifier allHostsValid = new HostnameVerifier() {
        public boolean verify(String hostname, SSLSession session) {
            return true;
        }
    };

    // Install the all-trusting host verifier
    HttpsURLConnection.setDefaultHostnameVerifier(allHostsValid);
}

请注意,出于安全考虑,不建议在生产环境中禁用 HTTPS 检查。

以上是通过 HTTPS 访问 Web 服务时,如何修复'java.security.cert.CertificateException:不存在主题备用名称”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn