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

标签 java protocol-buffers

能否获取序列化Protocol Buffer消息的Type?

我有这个例子

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

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

最佳答案

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

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

  • 文件扩展名
  • HTTP header
  • 帧基流协议(protocol)中的特定帧头
  • ...

关于java - Google Protocol Buffers,如何处理多种消息类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27248075/

相关文章:

Java 的新 Scanner vs Scanner.create()?

java - 如何使用 joox api for java 迭代 xml 文件?

java - 如何正确序列化/反序列化Java Object[]?

java - 从 Scanner 获取输入时 Maven 挂起

java - 创建 JNDI Java Bean 错误

java - GWT 单元表。沿行文本

c - 在嵌入式 ARM 系统 (STM32 F4) 上使用 protobuf-c 0.15

c++ - 注释 Protocol Buffer 中的推送 rpc 调用

c++ - 向 Protobuf 注入(inject)外部依赖?

c++ - 如何将重复的字段部分合并到消息中?