【SSL】错误java.security.UnrecoverableKeyException: Cannot recover key

本文介绍了解决Java安全异常UnrecoverableKeyException的方法,分析了错误产生的原因,并提供了两种解决方案,一种是将keystore密码和keypass密码设置为相同,另一种是在代码中分别指定这两个密码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

  • jdk1.8
  • window 7
  • eclipse 4.7
  • 执行之前已经成功执行过很多次的代码,发生错误java.security.UnrecoverableKeyException: Cannot recover key

分析

  • 经过网上查找为证书库中keypass密码不对所致。
  • 在执行代码前,我从其它证书库中拷贝了一个证书到原证书库中,但未对新的证书设置keypass

解决办法

  • 简单的解决办法:keystore密码和keypass密码使用相同的密码。
  • 另一个解决办法:如果有代码的话,可以将keystore密码和keypass密码分别指定。(多数情况下,代码中将keystore密码和keypass密码作为同一个配置项了)

修改keypass密码方法:

keytool -keystore <证书库文件> -storetype JKS -storepass <证书库密码> -keypasswd -alias <证书别名> -keypass <原keypass密码> -new <新keypass密码,与keystore密码一致>
要使用Volley实现SSL,您需要在您的应用程序中配置一个自定义的SSL Socket Factory。以下是一个简单的示例,它使用了自定义的SSL Socket Factory来实现Volley的HTTPS请求: 首先,您需要创建自定义的SSL Socket Factory。以下是一个示例: ```java public class CustomSSLSocketFactory extends SSLSocketFactory { private SSLContext sslContext = SSLContext.getInstance("TLS"); public CustomSSLSocketFactory(KeyStore truststore) throws NoSuchAlgorithmException, KeyManagementException, KeyStoreException, UnrecoverableKeyException { super(truststore); TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); trustManagerFactory.init(truststore); sslContext.init(null, trustManagerFactory.getTrustManagers(), null); } @Override public Socket createSocket(Socket socket, String host, int port, boolean autoClose) throws IOException, UnknownHostException { SSLSocket sslSocket = (SSLSocket) sslContext.getSocketFactory().createSocket(socket, host, port, autoClose); sslSocket.setEnabledProtocols(sslSocket.getSupportedProtocols()); return sslSocket; } @Override public Socket createSocket() throws IOException { SSLSocket sslSocket = (SSLSocket) sslContext.getSocketFactory().createSocket(); sslSocket.setEnabledProtocols(sslSocket.getSupportedProtocols()); return sslSocket; } } ``` 然后,您可以在您的应用程序中使用自定义的SSL Socket Factory 来创建一个 RequestQueue。以下是一个示例: ```java KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType()); keyStore.load(null, null); CustomSSLSocketFactory customSSLSocketFactory = new CustomSSLSocketFactory(keyStore); HurlStack stack = new HurlStack(null, customSSLSocketFactory); RequestQueue queue = Volley.newRequestQueue(context, stack); ``` 在以上示例中,我们首先创建一个空的 KeyStore。这个 KeyStore 将被用于创建我们的自定义 SSL Socket Factory。然后,我们创建了一个 CustomSSLSocketFactory 并传入 KeyStore。接下来,我们创建了一个新的 HurlStack 并传入 null 和我们的 CustomSSLSocketFactory。最后,我们使用这个 HurlStack 创建了一个新的 RequestQueue。 这样,您就可以使用自定义的SSL Socket Factory来实现Volley的HTTPS请求了。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值