javax.net.ssl.SSLHandshakeException: No appropriate protocol

在使用R2DBC连接MySQL时遇到 javax.net.ssl.SSLHandshakeException,错误提示缺少合适的协议。问题根源在于Java的安全配置中禁用了某些SSL协议。解决方案是编辑java.security文件,删除禁用SSLv3的配置。操作包括进入JDK安装目录的security文件夹,找到并删除相关配置,从而修复SSL握手异常问题。
摘要由CSDN通过智能技术生成

javax.net.ssl.SSLHandshakeException: No appropriate protocol

在r2dbc连接mysql是出现这个错误

com.alibaba.druid.pool.DruidDataSource   : create connection SQLException, url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai, errorCode 0, state 08S01
com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
...
Caused by: javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
	at sun.security.ssl.HandshakeContext.<init>(HandshakeContext.java:171)
	at sun.security.ssl.ClientHandshakeContext.<init>(ClientHandshakeContext.java:101)
	at sun.security.ssl.TransportContext.kickstart(TransportContext.java:238)
	at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:394)
	at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:373)
	at com.mysql.cj.protocol.ExportControlled.performTlsHandshake(ExportControlled.java:315)
	at com.mysql.cj.protocol.StandardSocketFactory.performTlsHandshake(StandardSocketFactory.java:188)
	at com.mysql.cj.protocol.a.NativeSocketConnection.performTlsHandshake(NativeSocketConnection.java:99)
	at com.mysql.cj.protocol.a.NativeProtocol.negotiateSSLConnection(NativeProtocol.java:352)
	... 13 common frames omitted

个人解决方法

1、进入jdk1.8.0_301\jre\lib\security文件夹编辑java.security文件找到对应的SSLv3
删除如图
2、进入文件夹jre1.8.0_301\lib\security文件夹编辑java.security文件找到对应的SSLv3
同样删除一样的配置即可

删除后图:
在这里插入图片描述

本人的解决方法,希望能帮到你。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值