jdk1.6访问https接口报错,jdk1.7访问正常,服务端jdk为1.7

jdk1.6访问https接口报错,jdk1.7访问正常,服务端jdk为1.7报错,对比正常访问密码套件不一样,可是我下载jce之后也没有用正常使用的是TLS,1.6使用的是MD5,如图:图片说明
图片说明

这个handshake failure是TLSv1 protocol 实现的一个bug,在java7中你这么做可能可以解决问题

java -Dhttps.protocols=TLSv1.2,TLSv1.1,TLSv1 

jvm会按照顺序选择执行哪一种TLS

Java都出9或者10了,新旧版本真的有很多优化特性,建议还是与时俱进尝试下新版本。

就是客户端与服务端jdk版本不一致,导致tls版本不一致,导致握手失败。可以在客户请请求的时候把前面大佬回答的协议加上去就行了,或者你客户端直接变成jdk1.7的就可以