我有一个Apache Http客户端,它需要连接到需要TLS 1.2的服务器,但现在这个客户端运行在jdk 1.6上,此时不可能进行升级。所以我选择了弹力城堡。我在我的Mac上进行了设置,如下面的post所示。
下面是我的代码,它使用了一个SSLContextBuilder...
import org.apache.http.ssl.SSLContextBuilder;
SSLContextBuilder sslContextBuilder = new SSLContextBuilder().loadTrustMaterial(null, new TrustStrategy() {
public boolean isTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {
return true;
}
});
// set SSL context builder to use TLSv1 protocoil
sslContextBuilder = sslContextBuilder.useProtocol("TLSv1.1");但是在这里的最后一行,我得到了这个异常...
Caught: java.security.NoSuchAlgorithmException: TLSv1.1 SSLContext not available
java.security.NoSuchAlgorithmException: TLSv1.1 SSLContext not available
at org.apache.http.ssl.SSLContextBuilder.build(SSLContextBuilder.java:271)看起来SSLContextBuilder没有看到我的BouncyCastle。或者我的BouncyCastle不支持TLS1.1?如果我把它改成"TLSv1“,它就能工作了。
或者,有没有更好的方法(将我的apache httpclient连接到bouncycastle,这样我的java6程序就可以连接到tlsv1.2服务器)?
发布于 2016-08-12 05:31:02
BouncyCastle只是一个JCE提供者(提供加密算法),而不是JSSE提供者(通过SSLSocket、SSLSocketFactory等提供SSL和TLS )。通过添加BouncyCastle作为安全提供者,您只需注册BouncyCastle提供者。更多信息here。
因为Apache也使用JSSE,所以您也不能插入HttpClient的TLS实现。您也许可以利用BouncyCastle的TLS实现来扩展Java的JSSE类,但这需要一些努力。
如果你想使用BouncyCastle的TLS实现,你可以找到一个示例in this thread。
https://stackoverflow.com/questions/38079928
复制相似问题