修复“java.security.cert.CertificateException:不存在主题备用名称”错误
使用以下命令通过 HTTPS 访问 Web 服务时Java 客户端遇到“java.security.cert.CertificateException:不存在主题备用名称”错误表示证书的主题名称与主机地址不匹配。
要解决此问题,请按照以下步骤操作:
但是,此方法可能并不总是有效如果您无法控制服务器的证书,则可行。
另一种解决方案是禁用 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中文网其他相关文章!