标签:
之前在工作中用到了protocol buffer(此处简称PB)(主要对数据进行序列化与反序列化,方便网络传输中的编解码),之后发现这是一个好东西,在此稍微记录下该工具如何使用,方便以后查阅
官网地址(需 翻 墙):https://developers.google.com/protocol-buffers/docs/downloads
在工程中使用PB ,首先需要准备好PB运行时库文件(.jar)文件,和PB编译器(protoc.exe,用于自动生成代码)
官网下载下来的PB源文件,需要编译打包成“.jar”文件,这样才能在之后的java工程中调用,此处介绍下打包PB源文件的 过程
下载下来的源文件解压后目录结构如下所示 :
将解压得到的PB编译器“protoc.exe”拷贝到上图所示的“src"目录(必需执行该操作,否则之后的mvn操作会失败)
进入上图所示的“java”目录,执行:mvn clean package,编译成功后便可在“target”目录下看见生成的.jar运行库文件。
至此打包生成库文件完成,之后便可调用生成的.jar文件。
protocol buffer是google 的一种数据交换的格式,它独立于语言,独立于平台,由于它是一种二进制的格式,比使用 xml 进行数据交换快许多。可以把它用于分布式应用之间的数据通信或者异构环境下的数据交换。作为一种效率和兼容性都很优秀的二进制数据传输格式,可以用于诸如网络传输、配置文件、数据存储等诸多领域,官网支持java、c++ 和 python,三种语言的实现。
下面介绍一下PB如何使用 :
message Login { required string account = 1; //用户名 optional string password = 2; //密码,默认没有 optional int32 version = 3; //版本号码 required string platform = 4; // “brew” required string device = 5; // “HS001C”,后面可能需要区分手持机还是车机 optional string meid = 6; // meid字串 optional uint32 expect_payload = 7 [default = 101]; //101指AMR,111是EVRC } message LoginAck { required int32 result = 1; //-1代表失败,>=0 代表成功 required User usr = 2; required Configure conf = 3; optional ServerInfo tcp_server = 4; // TCP 服务器 optional ServerInfo udp_server = 5; // UDP 服务器 optional ServerInfo update_server = 6; // 升级服务器 optional uint32 cookie = 7; //随机种子 } message QueryGroup { enum DetailLevel { ONLY_ID = 0; GROUP_INFO = 1; } required DetailLevel detail = 1 [default = GROUP_INFO]; //是只返回群组ID还是带群组名称的,默认是带名称的 optional bool include_temp = 2 [default = false]; //是否包括临时群组,默认是不包括的 } message QueryGroupAck { required int32 result = 1; //-1:fail >=0 succ repeated Group groups = 2; }
A scalar message field can have one of the following types – the table shows the type specified in the .proto
file, and the corresponding type in the automatically generated class:
命令行执行 : protoc.exe --java_out=./xxx.jar test.proto
protoc.exe --java_out=./ test.proto
Login.Builder builder = Login.newBuilder();
builder.setAccount(userName);
builder.setPlatform("brew");
builder.setDevice("HS001C");
builder.setPassword(pwd);
Login login = builder.build();
byte[] loginBt = login.toByteArray();
LoginAck loginAck = LoginAck.parseFrom(byteArray.getArray(byteArray.length() - 3)); int result = loginAck.getResult();
至此,PB使用基本介绍完成,下面贴出PB官网java 教程 :
标签:
原文地址:http://www.cnblogs.com/yinz/p/5067037.html