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; }