gRPC入门指南 — 通过TLS建立安全连接(五)

点击上方蓝色“Golang来啦”关注我哟

加个“星标”,天天 15 分钟,掌握 Go 语言

前言

前几篇文章大家看到的例子,通信双方都是没有经过 TLS 加密的。可以看下下面的抓包数据,都是明文的,生产环境上数据是绝对不允许这样“裸奔”的,数据容易被篡改。

conn, err := grpc.Dial(addr,grpc.WithInsecure())

接下来这篇文章就来给大家介绍下使用 TLS 加密数据。

生成证书

Go 1.15 版本开始废弃 CommonName[1],因此推荐使用 SAN 证书。如果想兼容之前的方式,需要设置环境变量 GODEBUG 为 x509ignoreCN=0。

这篇文章我们使用 SAN 证书。使用如下命令生成证书:

生成私钥
openssl genrsa -out server.key 2048

证书文件
openssl req -nodes -new -x509 -sha256 -days 1825 -config openssl.cnf -extensions 'req_ext' -key server.key -out server.crt

openssl x509 -in server.crt -text

上述命令依赖文件 openssl.cnf

[ req ]
default_bits = 2048
prompt = no
default_md = sha256
req_extensions = req_ext
distinguished_name = dn

[ dn ]
C = CN
ST = ZheJiang
L = Hangzhou
O = Seekload Ltd.
OU = Information Technologies
emailAddress = email@email.com
CN = localhost

[ req_ext ]
subjectAltName = @alt_names

[ alt_names ]
DNS.1 = localhost
DNS.2 = seekload.net
DNS.3 = www.seekload.net

执行完上述命令之后,会在目录下生成文件 server.key、server.crt。我们就可以拿这两个文件来加密数据。

关于证书的生成大家可以看下文末的参考文章,就不在这赘述。

Server端

package main

import (
 "context"
 pb "go-grpc-example/5-security/proto"
 "google.golang.org/grpc"
 "google.golang.org/grpc/credentials"
 "log"
 "net"
)

const (
 Address string = ":8000"
 Network string = "tcp"
)

type SimpleService struct{}

func (s *SimpleService) GetSimpleInfo(ctx context.Context, req *pb.SimpleRequest) (*pb.SimpleResponse, error) {
 data := req.Data
 log.Println("get from client: ", data)
 resp := pb.SimpleResponse{
  Code:  1,
  Value: "gRPC",
 }
 return &resp, nil
}

func main() {
 // 1.监听端口
 listener, err := net.Listen(Network, Address)
 if err != nil {
  log.Fatalf("listener err: %v", err)
 }
 log.Println(Address + " net.Listing...")

 // 为服务端构造TLS凭证
 creds, err := credentials.NewServerTLSFromFile("../cert/server.crt", "../cert/server.key")
 if err != nil {
  log.Fatalf("Failed to generate credentials %v", err)
 }

 // 2.实例化gRPC实例
 grpcServer := grpc.NewServer(grpc.Creds(creds))

 // 3.注册我们的服务
 pb.RegisterSimpleServer(grpcServer, &SimpleService{})

 // 4.启动gRPC服务端
 err = grpcServer.Serve(listener)
 if err != nil {
  log.Fatalf("grpc server err: %v", err)
 }
}

服务端代码修改点:

  • credentials.NewServerTLSFromFile() 根据服务端输入的证书文件和私钥构造 TLS 凭证;

  • grpc.Creds():返回一个 ServerOption,用于设置服务器连接的凭据;

Client端

package main

import (
 "context"
 pb "go-grpc-example/5-security/proto"
 "google.golang.org/grpc"
 "google.golang.org/grpc/credentials"
 "log"
)

const Address string = ":8000"

func main() {
 // 为客户端构造TLS凭证
 creds, err := credentials.NewClientTLSFromFile("../cert/server.crt", "localhost")
 if err != nil {
  log.Fatalf("Failed to create TLS credentials %v", err)
 }

 var DialOptions = []grpc.DialOption{
  grpc.WithTransportCredentials(creds),
 }

 // 连接服务端
 conn, err := grpc.Dial(Address, DialOptions...)
 if err != nil {
  log.Fatalf("grpc conn err: %v", err)
 }
 defer conn.Close()

 // 创建gRPC客户端
 grpcClient := pb.NewSimpleClient(conn)

 res := pb.SimpleRequest{
  Data: "seekload",
 }
 resp, err := grpcClient.GetSimpleInfo(context.Background(), &res)
 if err != nil {
  log.Fatalf("stream get from server err: %v", err)
 }
 log.Printf("get from server,code: %v,value: %v", resp.Code, resp.Value)
}

客户端修改点:

  • credentials.NewClientTLSFromFile() 从输入的证书文件中为客户端构造TLS凭证;

  • grpc.WithTransportCredentials() 指定安全连接,返回一个 DialOption,用于连接服务器。

验证

到此就已经完成 TLS 证书认证,gRPC 传输不再是明文传输,一起来验证看下

运行服务端:

go run server.go

:8000 net.Listing...
get from client:  seekload

运行客户端:

go run client.go
get from server,code: 1,value: gRPC

抓包看下:

数据已经加密无疑。

总结

这篇文章给大家简单介绍了使用 SAN 证书实现 TLS 加密,保证数据安全。

参考文章:
1.https://eddycjy.com/posts/go/grpc/2018-10-07-grpc-tls/
2.https://www.cnblogs.com/jackluo/p/13841286.html
3.https://lixueduan.com/post/grpc/04-encryption-tls/

参考资料

[1]

CommonName: https://golang.org/doc/go1.15#commonname

推荐阅读:

gRPC入门指南 — 双向流式RPC(四)

gRPC入门指南 — 客户端流式RPC(三)

gRPC入门指南 — 服务端流式RPC(二)

gRPC入门指南 — 简单RPC(一)

资料下载

点击下方卡片关注公众号,发送特定关键字获取对应精品资料!

  • 回复「电子书」,获取入门、进阶 Go 语言必看书籍。

  • 回复「视频」,获取价值 5000 大洋的视频资料,内含实战项目(不外传)!

  • 回复「路线」,获取最新版 Go 知识图谱及学习、成长路线图。

  • 回复「面试题」,获取四哥精编的 Go 语言面试题,含解析。

  • 回复「后台」,获取后台开发必看 10 本书籍。

对了,看完文章,记得点击下方的卡片。关注我哦~ ????????????

如果您的朋友也在学习 gRPC,相信这篇文章对 TA 有帮助,欢迎转发分享给 TA,非常感谢!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Seekload

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值