首页 > 后端开发 > Golang > 为什么 My Go TLS 拨号失败并显示'x509:证书依赖于旧版通用名称字段”?

为什么 My Go TLS 拨号失败并显示'x509:证书依赖于旧版通用名称字段”?

DDD
发布: 2024-10-28 08:13:02
原创
763 人浏览过

 Why Does My Go TLS Dial Fail with

Go TLS 拨号:无法连接依赖于旧版通用名称字段的 X509 证书

尝试连接到服务器时会出现此问题在 Golang 中使用 TLS,服务器的证书依赖于旧版通用名称 (CN) 字段进行识别。标准 Golang 库会检查主题备用名称 (SAN)。

原因:

默认情况下,Golang 运行时会根据最佳方式验证服务器证书是否存在 SAN安全实践。如果证书缺少 SAN,而是依赖 CN 字段进行标识,Go 运行时将拒绝连接,并显示错误消息:

failed to connect: x509: certificate relies on legacy Common Name field, use SANs or temporarily enable Common Name matching with GODEBUG=x509ignoreCN=0
登录后复制

解决方案:

要解决此问题,您有两个选择:

1。修改服务器证书以使用 SAN:

重新生成服务器证书以包含与客户端将用于连接的主机名或 IP 地址相对应的 SAN。这涉及使用证书颁发机构 (CA) 和 OpenSSL 命令来创建具有适当 SAN 的证书。

2.暂时禁用 CN 匹配:

您可以通过设置 GODEBUG 环境变量来临时禁用 Go 运行时对 SAN 的检查,如下所示:

GODEBUG=x509ignoreCN=0 go run your_program.go
登录后复制

注意:禁用 CN 匹配不是推荐的解决方案,因为它允许接受具有 CN 但不接受 SAN 的证书,从而降低了 TLS 连接的安全性。

以上是为什么 My Go TLS 拨号失败并显示'x509:证书依赖于旧版通用名称字段”?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板