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