当前位置:网站首页>go-grpc TSL认证 解决 transport: authentication handshake failed: x509 certificate relies on ... ...
go-grpc TSL认证 解决 transport: authentication handshake failed: x509 certificate relies on ... ...
2022-08-11 06:40:00 【咋么又饿了】
一、问题描述:transport: authentication handshake failed: x509: certificate relies on legacy Common Name field, use SANs or temporarily enable
二、背景环境:我的环境windows go 1.17,linux解决这个问题办法同样也适用。
三、首先需要 下载SSL
你点开这个链接以后会看到上面这图片显示的页面,我第一次下载的时候看见有个博客说随便点击一个下载,然后我也没仔细看,因为我的电脑是64位的,我就随便点了一个Win64的,然后好家伙,后面一共卸载下载了三次,不要下载forRAM的,会不允许安装,(ARM64是ARM中64位体系结构,x64是x86系列中的64位体系。ARM属于精简指令集体系,汇编指令比较简单。x86属于复杂指令集体系,汇编指令较多。属于两种不同的体系。看不懂没关系,你只要知道是两种不同的体系,那当然下载了也用不了)不要下载Light的,因为你会找不到后面所需要的openssl.cnf文件。
1、直接根据你的系统去下载最大的那两个其中之一。下载完成以后直接点开exe一直next安装好就可以了。
2、将openSSL的bin目录所在的路径放到path环境变量中,然后重启电脑。
3、生成普通的keyopenssl genrsa -des3 -out server.key 2048
(记住设置的密码,命令直接在终端上执行就好,我直接在goland的终端上执行的)
4、生成ca的crtopenssl req -new -x509 -key server.key -out ca.crt -days 3650
遇到填东西的直接回车就行
5、生成csropenssl req -new -key server.key -out server.csr
6、更改openssl.cnf (Linux 是openssl.cfg)
1)复制一份你安装的openssl的bin目录里面的openssl.cnf 文件到你项目所在的目录,我放在了keys文件夹下。
2)找到 [ CA_default ],打开 copy_extensions = copy (就是把前面的#去掉)
3)找到[ req ],打开 req_extensions = v3_req # The extensions to add to a certificate request
4)找到[ v3_req ],添加 subjectAltName = @alt_names
5)添加新的标签 [ alt_names ],和标签字段
DNS.1 = *.org.haha.com
DNS.2 = *.haha.com
7、生成证书私钥test.keyopenssl genpkey -algorithm RSA -out test.key
8、通过私钥test.key生成证书请求文件test.csr(注意cfg和cnf)
openssl req -new -nodes -key test.key -out test.csr -days 3650 -subj "/C=cn/OU=myorg/O=mycomp/CN=myname" -config ./openssl.cnf -extensions v3_req
test.csr是上面生成的证书请求文件。ca.crt/server.key是CA证书文件和key,用来对test.csr进行签名认证。这两个文件在第一部分生成。
9、生成SAN证书
openssl x509 -req -days 365 -in test.csr -out test.pem -CA ca.crt -CAkey server.key -CAcreateserial -extfile ./openssl.cnf -extensions v3_req
10、然后就可以用在 GO 1.15 以上版本的GRPC通信了
服务器加载代码
creds, err := credentials.NewServerTLSFromFile("test.pem", "test.key")
客户端加载代码
creds,err := credentials.NewClientTLSFromFile("test.pem","*.org.haha.com")
这个问题怎么说呢,试了很多的方法,最终使用这个方法解决了在这里记录一下。
感谢 thankyou~
边栏推荐
- Redis源码-String:Redis String命令、Redis String存储原理、Redis字符串三种编码类型、Redis String SDS源码解析、Redis String应用场景
- C语言每日一练——Day02:求最小公倍数(3种方法)
- Get Pinduoduo product information operation details
- docker安装mysql5.7(仅供测试使用)
- 联想集团:2022/23财年第一季度业绩
- 深度监督(中继监督)
- 接入网、承载网、核心网是什么,交换机路由器是什么、这个和网络的协议有什么关系呢?
- Amazon API interface Daquan
- Shell:三剑客之awk
- Taobao product details API interface
猜你喜欢
淘宝商品详情API接口
ROS 服务通信理论模型
EasyPlayer针对H.265视频不自动播放设置下,loading状态无法消失的解决办法
When MySQL uses GROUP BY to group the query, the SELECT query field contains non-grouping fields
linux 安装mysql服务报错
【LeetCode每日一题】——844.比较含退格的字符串
exness:黄金1800关口遇阻,静待美国CPI出炉
Daily sql: request for friend application pass rate
抖音API接口
Douyin API interface
随机推荐
亚马逊获得AMAZON商品详情 API 返回值说明
maxwell concept
EasyPlayer针对H.265视频不自动播放设置下,loading状态无法消失的解决办法
数仓开发知识总结
How Unity handles C# under the hood
prometheus学习5altermanager
Taobao sku API interface (PHP example)
How to choose professional, safe and high-performance remote control software
Cobbleland 博览会 基础系列 1
每日sql-统计各个专业人数(包括专业人数为0的)
强烈推荐一款好用的API接口
Taobao API common interface and acquisition method
MySQL使用GROUP BY 分组查询时,SELECT 查询字段包含非分组字段
exness:黄金1800关口遇阻,静待美国CPI出炉
Daily SQL - find each of the students school gpa minimum (window)
When MySQL uses GROUP BY to group the query, the SELECT query field contains non-grouping fields
Production and optimization of Unity game leaderboards
下一代 无线局域网--强健性
为什么C#中对MySQL不支持中文查询
Discourse 的关闭主题(Close Topic )和重新开放主题