社区精选|聊一聊 gRPC 中的拦截器
今天小编为大家带来的是社区作者 江南一点雨 的文章,让我们一起继续 gRPC 系列
一个简单的案例入门 gRPC https://mp.weixin.qq.com/s/OyfU0tLm4f9t3nZxce-Ksw 聊一聊 gRPC 的四种通信模式 https://mp.weixin.qq.com/s/c-_D2RpLksIlYJDfaWOSkA
服务端拦截器 客户端拦截器
1. 服务端拦截器

public class BookServiceCallListener<R> extends ForwardingServerCallListener<R> {
private final ServerCall.Listener<R> delegate;
public BookServiceCallListener(ServerCall.Listener<R> delegate) {
this.delegate = delegate;
}
@Override
protected ServerCall.Listener<R> delegate() {
return delegate;
}
@Override
public void onMessage(R message) {
System.out.println("这是客户端发来的消息,可以在这里进行预处理:"+message);
super.onMessage(message);
}
}
public class BookServiceCall<ReqT,RespT> extends ForwardingServerCall.SimpleForwardingServerCall<ReqT,RespT> {
protected BookServiceCall(ServerCall<ReqT, RespT> delegate) {
super(delegate);
}
@Override
protected ServerCall<ReqT, RespT> delegate() {
return super.delegate();
}
@Override
public MethodDescriptor<ReqT, RespT> getMethodDescriptor() {
return super.getMethodDescriptor();
}
@Override
public void sendMessage(RespT message) {
System.out.println("这是服务端返回给客户端的消息:"+message);
super.sendMessage(message);
}
}
public void start() throws IOException {
int port = 50051;
server = ServerBuilder.forPort(port)
.addService(ServerInterceptors.intercept(new BookServiceImpl(), new ServerInterceptor() {
@Override
public <ReqT, RespT> ServerCall.Listener<ReqT> interceptCall(ServerCall<ReqT, RespT> call, Metadata headers, ServerCallHandler<ReqT, RespT> next) {
String fullMethodName = call.getMethodDescriptor().getFullMethodName();
System.out.println(fullMethodName + ":pre");
Set<String> keys = headers.keys();
for (String key : keys) {
System.out.println(key + ">>>" + headers.get(Metadata.Key.of(key, ASCII_STRING_MARSHALLER)));
}
return new BookServiceCallListener<>(next.startCall(new BookServiceCall(call), headers));
}
}))
.build()
.start();
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
BookServiceServer.this.stop();
}));
}
第一个参数 call 是消费传入的 RPC 消息的一个回调。 第二个参数 headers 则是请求的消息头,如果我们通过 JWT 进行请求校验,那么就从这个 headers 中提取出请求的 JWT 令牌然后进行校验。 第三个参数 next 就类似于我们在 Java 过滤器 filter 中的 filterChain 一样,让这个请求继续向下走。
2. 客户端拦截器
ManagedChannel channel = ManagedChannelBuilder.forAddress("localhost", 50051)
.usePlaintext()
.intercept(new ClientInterceptor() {
@Override
public <ReqT, RespT> ClientCall<ReqT, RespT> interceptCall(MethodDescriptor<ReqT, RespT> method, CallOptions callOptions, Channel next) {
System.out.println("!!!!!!!!!!!!!!!!");
callOptions = callOptions.withAuthority("javaboy");
return next.newCall(method,callOptions);
}
})
.build();
BookServiceGrpc.BookServiceStub stub = BookServiceGrpc.newStub(channel);
当我们的请求执行的时候,这个客户端拦截器就会被触发。
3. 小结


关注公众号:拾黑(shiheibook)了解更多
赞助链接:
关注数据与安全,洞悉企业级服务市场:https://www.ijiandao.com/
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/

随时掌握互联网精彩
- Apache ECharts:基于原生 JS 的开源可视化图表库
- “鹅厂希望”视频号,成了微信公开课的主角
- 【杂谈快报】三大唱片公司与TikTok谈判,要求从广告收入中抽成;2022年世界互联网大会乌镇峰会开幕
- 深度解读 | CTO亲述微软20多年的商业秘诀
- 中国移动在CCSA完成无线算力网络场景、需求和关键技术研究项目立项
- 对比InfluxDB和TDengine 基于InfluxDB
- 华为在孟晚舟事件中的叙事技巧:一家没有形容词的公司
- 700M 5G网络建设时间表:年内完成20万站,明年续建28万站
- 特斯拉暂停扩建上海工厂;消息称瑞幸前高管陆正耀再创业;小米被美国移出“黑名单”|Do早报
- 为什么共享充电宝能赚钱,共享单车不行?
- 美国CSIS发布《2030年全球网络:发展中经济体和新兴技术》报告
- 苹果推出新的“Find My”安全功能;英国对苹果启动反垄断调查;快手服务号上线“10亿补贴计划”|Do早报
赞助链接