我一直在收到以下错误:
com.microsoft.sqlserver.jdbc.SQLServerException: The driver could not establish a secure connection to SQL Server by using Secure Sockets Layer (SSL) encryption. Error: "SQL Server did not return a response. The connection has been closed. ClientConnectionId:be8d9e1d-fff7-4310-ae77-03394c83f86b".
(POST底部的更多错误(尝试连接到MSSQL数据库时。
我正在使用以下连接字符串:
jdbc:sqlserver://192.168.100.190:1433;databaseName=myDatabase;user=validUser;password=validPassword;encrypt=false;trustServerCertificate=false;sslProtocol=TLSv1;
我尝试了连接字符串的变体,本质上是更改和省略的:
encrypt=false;trustServerCertificate=false;sslProtocol=TLSv1;
我尝试了以下驱动程序的不同版本:
https://learn.microsoft.com/en-us/sql/connect/jdbc/download-microsoft-jdbc-jdbc-jdbc-driver-for-sql-sql-server?view=sql-server-server-server-2017
所有结果都相同。
- 重要的是要注意,在某些PC上,应用程序连接并且按预期工作,但到目前为止我还没有发现真正的差异在PC的或用户帐户之间,实际上没有模式。
- 我尝试了JDK和不同JRE的不同版本,给出相同的结果。更新:从那以后我发现JRE 1.8.0_152在我的所有测试用例中都可以使用
- 我尝试在服务器上查看日志,但没有条目SQL日志。
- 如果我尝试使用错误凭据的连接字符串,则错误是完全一样。
- 我已经设置了一个测试服务器和数据库,这很好,一个我也可以在虚拟机中设置。
- 我可以使用NAVICAT连接到所述数据库,例如另一个应用程序,用Visual Basic.net编写,它可以很好地连接,因此,它会看到这只是该驱动程序或Java的东西,但是正如我所说,它确实在某些PC上可以使用,而不是其他PC,当然也可以在我的测试环境中按预期工作。
任何想法或建议都将不胜感激。
我没有提供任何代码,因为我可以使用此处提供的示例代码复制完全相同的结果:
https://learn.microsoft.com/en-us/sql/connect/jdbc/step-3-prood-of-concept-concept-connecting-connecting-to-sql-using-using-usis-java?view = sql-server-server-2017
更多有关错误的详细信息:
com.microsoft.sqlserver.jdbc.SQLServerException: The driver could not establish a secure connection to SQL Server by using Secure Sockets Layer (SSL) encryption. Error: "SQL Server did not return a response. The connection has been closed. ClientConnectionId:be8d9e1d-fff7-4310-ae77-03394c83f86b".
at com.microsoft.sqlserver.jdbc.SQLServerConnection.terminate(SQLServerConnection.java:2670)
at com.microsoft.sqlserver.jdbc.TDSChannel.enableSSL(IOBuffer.java:1837)
at com.microsoft.sqlserver.jdbc.SQLServerConnection.connectHelper(SQLServerConnection.java:2257)
at com.microsoft.sqlserver.jdbc.SQLServerConnection.login(SQLServerConnection.java:1921)
at com.microsoft.sqlserver.jdbc.SQLServerConnection.connectInternal(SQLServerConnection.java:1762)
at com.microsoft.sqlserver.jdbc.SQLServerConnection.connect(SQLServerConnection.java:1077)
at com.microsoft.sqlserver.jdbc.SQLServerDriver.connect(SQLServerDriver.java:623)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at database.DataBase.openConnection(DataBase.java:122)
at jambuddylite.jblCoord.readSimex(jblCoord.java:387)
at jambuddylite.jblCoord$2.run(jblCoord.java:314)
at java.lang.Thread.run(Unknown Source)
Caused by: java.io.IOException: SQL Server did not return a response. The connection has been closed. ClientConnectionId:be8d9e1d-fff7-4310-ae77-03394c83f86b
at com.microsoft.sqlserver.jdbc.TDSChannel$SSLHandshakeInputStream.ensureSSLPayload(IOBuffer.java:780)
at com.microsoft.sqlserver.jdbc.TDSChannel$SSLHandshakeInputStream.readInternal(IOBuffer.java:836)
at com.microsoft.sqlserver.jdbc.TDSChannel$SSLHandshakeInputStream.read(IOBuffer.java:827)
at com.microsoft.sqlserver.jdbc.TDSChannel$ProxyInputStream.readInternal(IOBuffer.java:1009)
at com.microsoft.sqlserver.jdbc.TDSChannel$ProxyInputStream.read(IOBuffer.java:997)
at sun.security.ssl.InputRecord.readFully(Unknown Source)
at sun.security.ssl.InputRecord.read(Unknown Source)
at sun.security.ssl.SSLSocketImpl.readRecord(Unknown Source)
at sun.security.ssl.SSLSocketImpl.performInitialHandshake(Unknown Source)
at sun.security.ssl.SSLSocketImpl.startHandshake(Unknown Source)
at sun.security.ssl.SSLSocketImpl.startHandshake(Unknown Source)
at com.microsoft.sqlserver.jdbc.TDSChannel.enableSSL(IOBuffer.java:1767)
... 11 more
检查端口是打开的还是不使用CMD或终端上的
telnet 192.168.100.190 1433
并检查数据库名称和凭据
和防火墙我认为
有一些东西并在这里看看可能会帮助您