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

被折叠的 条评论
为什么被折叠?



