驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe

本文针对下方的异常信息进行解决,希望对您的编程有所帮助!

异常信息

驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or cipher suites are inappropriate)"

运行环境

JDK/JRE:1.8.0_212
编译器:Eclipse 2021-06 (4.20.0)
SQL SERVER: 2008

异常描述

使用JDBC连接SQL SERVER时出现如下错误

Exception in thread "main" com.microsoft.sqlserver.jdbc.SQLServerException: 驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:No appropriate protocol (protocol is disabled or cipher suites are inappropriate)”。
	at com.microsoft.sqlserver.jdbc.SQLServerConnection.terminate(SQLServerConnection.java:1368)
	at com.microsoft.sqlserver.jdbc.TDSChannel.enableSSL(IOBuffer.java:1412)
	at com.microsoft.sqlserver.jdbc.SQLServerConnection.connectHelper(SQLServerConnection.java:1058)
	at com.microsoft.sqlserver.jdbc.SQLServerConnection.login(SQLServerConnection.java:833)
	at com.microsoft.sqlserver.jdbc.SQLServerConnection.connect(SQLServerConnection.java:716)
	at com.microsoft.sqlserver.jdbc.SQLServerDriver.connect(SQLServerDriver.java:841)
	at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:677)
	at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:228)
	at Main.main(Main.java:16)
Caused by: javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
	at java.base/sun.security.ssl.HandshakeContext.<init>(HandshakeContext.java:172)
	at java.base/sun.security.ssl.ClientHandshakeContext.<init>(ClientHandshakeContext.java:98)
	at java.base/sun.security.ssl.TransportContext.kickstart(TransportContext.java:238)
	at java.base/sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:444)
	at java.base/sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:422)
	at com.microsoft.sqlserver.jdbc.TDSChannel.enableSSL(IOBuffer.java:1379)
	... 7 more

错误原因

有可能是JRE的加密算法与SQL SERVER的加密算法不匹配导致的,且目前Eclipse较新的版本使用的都是自带的JRE,因此错误原因可能是Eclipse中自带的JRE的加密算法与SQL SERVER的加密算法的不匹配导致连接失败

解决方法

由于是Eclipse中的JRE出现了问题,因此只需要将Eclipse的JRE切换成我们自己的JRE即可,步骤如下:

添加Eclipse中的JRE

打开
Eclipse -> Window -> Perferences -> Java -> Installed JREs
出现如下界面
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第1张图片
第一个是Eclipse自带的JRE (与SQL SERVER连接会报错)
第二个是我后来添加的,后续将演示如何添加JRE。

选择上图界面中右侧的 “Add” 按钮
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第2张图片
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第3张图片
如果忘记了JDK的安装路径,可以打开命令行输入如下指令查看

echo %JAVA_HOME%

选择jre文件夹
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第4张图片
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第5张图片
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第6张图片

为自己添加的JRE上打勾,保存并关闭。
到此,即完成了Eclipse的JRE的添加,要在项目中运用,还需配置如下:

修改项目中的JRE版本

驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第7张图片
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第8张图片
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第9张图片
这里一定要选择带版本号的,这才是我们自己JDK中自带的JRE,而非Eclipse中自带的JRE。
到此,项目的JRE修改已经完成,可以测试自己的项目是否还会出现异常。
—END—
后续新建项目时,可先指定好JRE,就不必再手动去配置JRE版本了,要是嫌麻烦,可以在添加JRE界面中直接将Eclipse中自带的JRE配置删除(见下方图二)
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第10张图片驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“No appropriate protocol(protocol is disabled or ciphe_第11张图片

你可能感兴趣的:(Eclipse使用,sqlserver,eclipse,jdbc)