尝试使用自签名证书建立与网站的连接时由于证书验证失败,Java应用程序可能会遇到错误。本文提出了在遵守特定要求的同时解决此问题的解决方案。
建议的方法是创建一个包含受信任的自签名证书的自定义 SSLSocketFactory。这允许应用程序有选择地信任特定连接的证书。实现方法如下:
加载包含自签名证书的 KeyStore:
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType()); keyStore.load(trustStore, trustStorePassword); trustStore.close();
创建TrustManagerFactory进行初始化TrustManagers:
TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); tmf.init(keyStore);
初始化 SSLContext 并获取 SSLSocketFactory:
SSLContext ctx = SSLContext.getInstance("TLS"); ctx.init(null, tmf.getTrustManagers(), null); sslFactory = ctx.getSocketFactory();
使用以下命令配置 HttpsURLConnection SSLSocketFactory:
HttpsURLConnection conn = (HttpsURLConnection)url.openConnection(); conn.setSSLSocketFactory(sslFactory);
以上是如何信任特定 Java 连接的自签名证书?的详细内容。更多信息请关注PHP中文网其他相关文章!