
gRPC拦截器:巧妙设置Cookie
gRPC框架允许通过拦截器机制灵活地管理请求和响应,其中包括设置和读取Cookie。以下代码示例演示了如何利用gRPC拦截器实现Cookie的设置:
import (
"context"
"fmt"
"net/http"
"google.golang.org/grpc"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/metadata"
"google.golang.org/grpc/status"
)
// cookie设置拦截器
func SetCookieInterceptor(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (interface{}, error) {
// 从传入请求中提取metadata
md, ok := metadata.FromIncomingContext(ctx)
if !ok {
return nil, status.Errorf(codes.Internal, "failed to extract metadata")
}
// 检查是否存在名为"cookie"的metadata
cookies, ok := md["cookie"]
if !ok {
return handler(ctx, req) // Cookie不存在,继续处理
}
// 设置Cookie到响应中 (需要在实际应用中替换ResponseWriter)
cookie := &http.Cookie{
Name: "my-cookie",
Value: cookies[0],
}
// 此处需要根据实际情况设置cookie,例如使用ResponseWriter
fmt.Printf("Setting cookie: %+v\n", cookie)
// 继续处理请求
return handler(ctx, req)
}
// 创建gRPC一元拦截器
func NewUnaryServerInterceptor() grpc.UnaryServerInterceptor {
return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (interface{}, error) {
return SetCookieInterceptor(ctx, req, info, handler)
}
}
这段代码定义了一个拦截器SetCookieInterceptor,它从传入的gRPC请求的元数据中提取名为“cookie”的字段,并将值作为Cookie设置到响应中。 NewUnaryServerInterceptor 函数创建了一个gRPC一元拦截器,方便将SetCookieInterceptor添加到gRPC服务中。 请注意:代码中http.SetCookie(w, cookie)部分需要根据你的实际应用场景替换为合适的Cookie设置方法,例如使用一个ResponseWriter。 通过将NewUnaryServerInterceptor注册到gRPC服务器,就能在每次请求处理前设置Cookie。










