(已解决)java连接数据库失败PKIX path building failed
环境:eclipse,sql server 2022,JDK19
用的JDBC:mssql-jdbc-12.2.0.jre11.jar
连接数据库时发生错误:
com.microsoft.sqlserver.jdbc.SQLServerException: 驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target”。
data:image/s3,"s3://crabby-images/acffe/acffe893224fd7c5e922cc17b7d1f9eda1654d6e" alt=""
在网上找了一晚,没什么解决方案(我tm好难受啊)
在看了官方文档找到了答案;网址:使用加密进行连接 - JDBC Driver for SQL Server | Microsoft Learn
这是改之前的代码:
data:image/s3,"s3://crabby-images/108d6/108d67361910e8706cf09443ff4a8c9115022a48" alt=""
在url那加个属性,使encrypt 属性设置为 true 且 trustServerCertificate 属性设置为 true 时,Microsoft JDBC Driver for SQL Server 将不验证SQL Server TLS 证书
如图:
data:image/s3,"s3://crabby-images/5711d/5711d4856993d5684c202c76ae2a1c8143bcac2c" alt=""
就这样解决了
data:image/s3,"s3://crabby-images/7acdc/7acdc114196e0f456fced41bf8ef4cbe0a69e83f" alt=""
要复制代码看官方文档,里面有的