java - java 应用程序连接到 MSSQL 数据库时出现 : com. microsoft.sqlserver.jdbc.SQLServerException 问题

标签 java sql-server mssql-jdbc

我收到以下错误:

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".

(更多错误位于帖子底部) 当尝试连接到 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-driver-for-sql-server?view=sql-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-proof-of-concept-connecting-to-sql-using-java?view=sql-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

并检查数据库名称和凭据

和防火墙,我认为防火墙中有一些东西

看看here可能对你有帮助

关于java - java 应用程序连接到 MSSQL 数据库时出现 : com. microsoft.sqlserver.jdbc.SQLServerException 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55933082/

相关文章:

C# 未将对象引用设置为对象的实例

spring-boot - Spring Boot中的MS SQL Server数据源Java配置

sql-server - 在 Microsoft SQL Server 中从十六进制文字插入 varbinary 值

java - 这是我的代码。当我执行它时,一个空字符串被插入到数据库中。但是,我对数据库中的所有字段使用 varchar 20

java - Java 8 中的 Collections.sort 在比较器返回 0 时不能像 Java 6 那样工作

java - 如何使用java代码设置html文本字段的值

java - 在 Tomcat 7.0 上运行网站 : Windows 2008 R2

SQL Server : loop through every row, 向列添加增量值

java - 为什么这个md5不匹配

java - 项目和 Maven 依赖项中的同一类