我需要连接到只接受通过TLS 1.2建立的连接的Web服务。其他版本不受支持。
我的测试客户端(soapUI Pro)使用JRE 1.7_45,根据以下链接,它通常支持默认情况下不为客户端启用的TLS 1.2。我无法控制测试客户端的源代码,所以我需要通过一些Java选项来启用TLS 1.2。
http://docs.oracle.com/javase/7/docs/technotes/guides/security/SunProviders.html#tlsprotonote
但是我找不到任何有关如何为JVM启用TLS 1.2的信息。
答案 0 :(得分:27)
必须将以下参数添加到soapUI的bin目录中的soapUI vmoptions文件中:
-Dsoapui.https.protocols=TLSv1.2
答案 1 :(得分:8)
您需要将协议传递给SSLContext
- docs
SSLContext context = SSLContext.getInstance("TLSv1.2");
然后,您可以使用context
创建SSLEngine
context.createSSLEngine();
使用SSLEngine