protobuf通信消息设计技巧备忘

1. 有一个全局的ProtobufMessage, 所有的requestXXX, responseXXX都作为他的一个可选属性, 这样简单粗暴的避免了需要二次序列化反序列化的恶心问题

2. 有一个CommonMessage作为他的一个字段,用来存放公共字段。变相解决了reuqest消息和response消息的继承问题

3. 这样之后对于wireshark抓包后,反序列化以及格式化为JSON极其便利

 

 

syntax = "proto3";
option java_package = "com.example.foo";
option java_outer_classname = "Ponycopter";

import "google/protobuf/any.proto";

message CommonMessage {
	int64 userId = 1;
	string token = 2;
}

message ProtobufMessage {
	CommonMessage commonMessage = 1;
	SearchRequest searchRequest = 2;
	SearchResponse searchResponse = 3;
        ...
}

message SearchRequest {
	string query = 1;
}
message SearchResponse {
	
}
message ErrorStatus {
  string message = 1;
  repeated google.protobuf.Any details = 2;
  map<string, int32> projects = 3;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值