gRPC-09 传递header信息/元数据 [golang版]

19 篇文章 11 订阅

代码地址

https://github.com/wanmei002/grpc-learn/tree/master/ch08
逻辑都在拦截器里实现了,可以直接看 拦截器 的代码

介绍

像一些 token 等数据 我们可能希望通过 header头传递,gRPC的数据先传递到 context 里,然后再写到 header 头里,然后
传递给另一端。

直接上代码

客户端

header 数据的写入

需要导入 google.golang.org/grpc/metadata 这个包

headerData := metadata.Pairs("timestamp", strconv.Itoa(int(time.Now().Unix())), "token", "123")
ctxH := metadata.NewOutgoingContext(ctx, headerData)
// 后续也可以往后面添加数据
ctxH = metadata.AppendToOutgoingContext(ctxH, "kay1", "val1", "key2", "val2")

ctxH就是一个上下文,请求服务端时,传的 context.Context 替换成 ctxH 就行

读取 header 信息

header 头信息也可能通过 trailer 传递

一元模式读取 header 信息
var header, trailer metadata.MD
// 调用服务端方法的时候可以在后面传参数
serverRetMsg, err := client.RPCMethod(ctx, &Struct, grpc.Header(&header), grpc.Trailer(&trailer))
流模式读取 header 信息
stream, err := client.RequestServerStreamMethod(ctx)
header, err := stream.Header()
trailer := stream.Trailer()

服务端

header 头信息的写入
一元模式 数据的写入
header := metadata.Pairs("token", "123")
grpc.SendHeader(ctx, header)
trailer := metadata.Pairs("is-end", "end")
grpc.SetTrailer(ctx, trailer)
流模式 数据的写入

跟一元的一样,服务端提供的方法传进来的流参数里面有相关的方法

header := metadata.Pairs("token", "123")
stream.SendHeader(ctx, header)
trailer := metadata.Pairs("is-end", "end")
stream.SetTrailer(ctx, trailer)
header 头信息的读取
一元模式 数据的读取
md, ok := metadata.FromIncomingContext(ctx)
流模式 数据的读取
md, ok := metadata.FromIncomingContext(stream.Context())
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值