记一次问题:

报错:

javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)

这个问题是在我进行接口对接的时候产生的,我方没有对服务jdk版本进行过调整,对接的那一方也进行了沟通,也没有对进口进行过修改,就很奇怪了,算了,既然有问题了就需要解决了,是谁产生的已经不重要了。。。。

排查原因:提示给出SSL异常,翻译为:没有合适的协议(协议被禁用或密码套件不合适)。

根据在网上查到的问题解决办法,说是对于高的jdk版本,对于SSL调用权限有限制,需要对jdk中的配置进行修改,可是找了好久,给出的几乎都是jdk1.8的处理,我们用的是jdk11,配置中的路径都不一样,最后通过自己胡乱一通找,终于在jdk11里找到相应的修改配置的地方了。

都是修改java.security文件,jdk1.8是在/Library/Java/JavaVirtualMachines//jdk1.8.jdk/Contents/Home/jre/lib/security/java.security下,而jdk11没有jre文件夹了已经,文件在/Library/Java/JavaVirtualMachines/jdk-11.0.12.jdk/Contents/Home/conf/security/java.security路径下。总而言之,都要先找到security文件夹,才能找到相应文件,找到文件之后去除 jdk.tls.disabledAlgorithms 中 SSLv3, TLSv1, TLSv1.1三项协议,然后重启项目就可以啦。

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐