首页 » SEO优化 » phpprotobufmaster技巧_简单介绍Protobuf协议

phpprotobufmaster技巧_简单介绍Protobuf协议

访客 2024-12-12 0

扫一扫用手机浏览

文章目录 [+]

来看看几张图你就知道它有多变态。

phpprotobufmaster技巧_简单介绍Protobuf协议

Protobuf的Java实例一、 安装Protobuf

去Protobuf的GitHub下载,解压。

phpprotobufmaster技巧_简单介绍Protobuf协议
(图片来自网络侵删)

如果你是Windows环境,则还要下载多一个东西。
protobuf-2.5.0-windows.zip。

解压protobuf-2.5.0-windows.zip,把protoc.exe放在Protobuf安装目录下的src里。
(实在放哪都可以)

二、 配置环境变量

编辑系统变量Path,添加Protoc.exe的存放目录。

三、 Eclipse新建项目

我利用maven构建protobuf项目,方便引入protobuf-java-2.5.0.jar依赖。
在项目根目录创建proto文件夹,存放proto文件。

maven依赖pom.xml

<dependency> <groupId>com.google.protobuf</groupId> <artifactId>protobuf-java</artifactId> <version>2.5.0</version></dependency>12345四、编写.proto文件

在proto文件夹下编写person-entity.proto,如下(proto协议的规则点这查看)

option java_outer_classname = "PersonEntity";//天生的数据访问类的类名 message Person { required int32 id = 1;//同上 required string name = 2;//必须字段,在后面的利用中必须为该段设置值 optional string email = 3;//可选字段,在后面的利用中可以自由决定是否为该字段设置值} 123456四、利用protoc.exe编译成java类

有两种方法:1. 利用Java Rumtime实行cmd命令2. 直接打开cmd运行命令也行。

1. 利用Java Rumtime实行cmd命令

util包下新建GenerareClass类

/ protoc.exe @author ganhaibin /public class GenerateClass { public static void main(String[] args) { String protoFile = "person-entity.proto";// String strCmd = "d:/dev/protobuf-master/src/protoc.exe -I=./proto --java_out=./src/main/java ./proto/"+ protoFile; try { Runtime.getRuntime().exec(strCmd); } catch (IOException e) { e.printStackTrace(); }//通过实行cmd命令调用protoc.exe程序 }}12345678910111213141516

命令格式如下。

protoc.exe -I=proto的输入目录 --java_out=java类输出目录 proto的输入目录包括包括proto文件12. 直接打开cmd运行命令

天生的PersonEntity.java类

五、测试

编写Test类,仿照序列化和反序列化过程。

public class Test { public static void main(String[] args) throws IOException { //仿照将工具转成byte[],方便传输 PersonEntity.Person.Builder builder = PersonEntity.Person.newBuilder(); builder.setId(1); builder.setName("ant"); builder.setEmail("ghb@soecode.com"); PersonEntity.Person person = builder.build(); System.out.println("before :"+ person.toString()); System.out.println("===========Person Byte=========="); for(byte b : person.toByteArray()){ System.out.print(b); } System.out.println(); System.out.println(person.toByteString()); System.out.println("================================"); //仿照吸收Byte[],反序列化成Person类 byte[] byteArray =person.toByteArray(); Person p2 = Person.parseFrom(byteArray); System.out.println("after :" +p2.toString()); }}123456789101112131415161718192021222324

输出如下

相关文章