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

猜你喜欢

转载自yuancihang.iteye.com/blog/2337743