登录
首页 >  Golang >  Go问答

连接到远程 SQL Server 时遇到 TLS 握手失败的问题解决方法

来源:stackoverflow

时间:2024-02-27 13:42:23 112浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《连接到远程 SQL Server 时遇到 TLS 握手失败的问题解决方法》,聊聊,我们一起来看看吧!

问题内容

这是我尝试连接 sql server 时的代码:

connString := fmt.Sprintf("server=%s;user id=%s;password=%s¡port=%s;databases=%s", server, user, password, port, database)

// if there is an error opening the connection, handle it
if err != nil {
  // simply print the error to the console 
  fmt.Println("Err", err.Error())
}

err.Error()) // returna nit on error

defer db.Close()

results, err := db.query("SELECT employee_id, display_name from `person_tbl`")

if err != nil {
  fmt.Println("Err", err.Error())
}
fmt.Print (results)

当我尝试连接到sql server时,我收到错误消息 “err tls 握手失败:tls:服务器选择了不支持的协议版本 301” 我尝试在服务器上将 tls 更改为版本 1.2,但仍然收到相同的错误消息。我需要再次重置我的 tls 还是需要向我的 go-lang 代码添加代码?


正确答案


“不支持的协议版本”301 表示服务器选择的不安全的 tls 版本 (1.0)。 (和 301:永久重定向)

确保您要连接的 sql 服务器支持最新的 tls 版本(例如 TLS 1.2 for a Microsoft SQL Server)。

我尝试在服务器上将 tls 更改为版本 1.2

仔细检查此 change was effective

  • a) tls1.0 --> curl -v -s --tlsv1.0 https:// -o /dev/null/ 2>&1
  • b) tls1.1 --> curl -v -s --tlsv1.1 https:// -o /dev/null/ 2>&1
  • c) tls1.2 --> curl -v -s https:// -o /dev/null/ 2>&1

您必须更新 microsoft sql server 以支持最新的 tls,否则安全性较低,您可以禁用连接字符串上的加密,如下例所示。

connectionString: "sqlserver://user@SERVIDOR/SQL2012?database=dbexample&encrypt=disable&connection+timeout=30"

以上就是《连接到远程 SQL Server 时遇到 TLS 握手失败的问题解决方法》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>