Google Protocol Buffers,如何处理多种消息类型?

时间:2014-12-02 11:17:33

标签: java protocol-buffers

是否可以获取序列化协议缓冲区消息的类型?

我有这个例子

option java_outer_classname="ProtoUser";

message User {
    required int32  id = 1; 
    required string name = 2;
    required string firstname = 3;
    required string lastname = 4;
    required string ssn= 5; 
}

message Address {
    required int32 id = 1;
    required string country = 2 [default = "US"];; 
    optional string state = 3;
    optional string city = 4;
    optional string street = 5;
    optional string zip = 6;
}

在Java中我有这段代码

Address addr = ProtoUser.Address.newBuilder().setCity("Weston").setCountry("USA").setId(1).setState("FL").setStreet("123 Lakeshore").setZip("90210")
            .build();

    User user = ProtoUser.User.newBuilder().setId(1).setFirstname("Luis").setLastname("Atencio").setName("luisat").setSsn("555-555-5555").build();

if(....){
    FileOutputStream output = new FileOutputStream("out1.ser");
    user.writeTo(output);
    output.close();
}else{
    FileOutputStream output = new FileOutputStream("out1.ser");
    addr.writeTo(output);
    output.close();
}

现在,我可以确定该文件是包含地址还是用户?处理多个消息类型的常用方法是什么?如何确定收到的消息类型?

2 个答案:

答案 0 :(得分:5)

我们无法确定该文件是包含地址还是用户。因为数据中没有编码类型信息。

要处理多个消息类型,您可以使用以下元数据:

  • 文件名扩展名
  • HTTP中的标头
  • 帧基流协议中的特定帧头
  • ...

答案 1 :(得分:1)

要么你:

  1. 在文件结尾处包含这是地址或名称的信息(如果文件一次只包含一种类型)
  2. 以序列化形式明确指定数据包的类型,即添加字段required int32 type并从该字段中推断出类型。 (如果两种类型一次包含在一个文件中)
  3. 设计一个特定的外部消息格式,明确包含此信息并包装协议缓冲区。
  4. 如果您将它们复用到一个通道上(无论您选择相同的文件结尾),您都必须在收到它们时再次对它们进行解复用。