先导入依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.meng</groupId>
<artifactId>protobuf</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<grpc.version>1.6.1</grpc.version>
<protobuf.version>3.3.0</protobuf.version>
</properties>
<dependencies>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.59</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.18</version>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-netty</artifactId>
<version>${grpc.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-protobuf</artifactId>
<version>${grpc.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-stub</artifactId>
<version>${grpc.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>${protobuf.version}</version>
</dependency>
</dependencies>
<build>
<extensions>
<extension>
<groupId>kr.motd.maven</groupId>
<artifactId>os-maven-plugin</artifactId>
<version>1.5.0.Final</version>
</extension>
</extensions>
<plugins>
<plugin>
<groupId>org.xolstice.maven.plugins</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<version>0.5.0</version>
<configuration>
<protocArtifact>com.google.protobuf:protoc:${protobuf.version}:exe:${os.detected.classifier}</protocArtifact>
<pluginId>grpc-java</pluginId>
<pluginArtifact>io.grpc:protoc-gen-grpc-java:${grpc.version}:exe:${os.detected.classifier}</pluginArtifact>
</configuration>
<executions>
<execution>
<goals>
<goal>compile</goal>
<goal>compile-custom</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>6</source>
<target>6</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
然后写teacher.proto,这里文件目录要在main下面,而且文件夹名字是proto不能乱改
syntax = "proto3";
option java_package="protobuf";
option java_outer_classname="TeacherSerializer";
message Teacher{
int64 id=1;
int32 age=2;
string name=3;
repeated string courses=4;
}
利用插件生成序列化代码,如图
双击,生成
将生成的文件拷贝到domain下即可。
写一个测试类
package domain;
import com.google.protobuf.InvalidProtocolBufferException;
import java.util.Arrays;
/**
* @author Administrator
*/
public class ProtobufTest {
public static void main(String[] args) throws InvalidProtocolBufferException {
byte[] bytes = serialize();
System.out.println(Arrays.toString(bytes));
TeacherSerializer.Teacher teacher = deserialize(bytes);
System.out.println(teacher.getId()+"\t"+teacher.getName()+"\t"+teacher.getAge()+"\t"+teacher.getCoursesList());
}
/**序列化
*
* @return
*/
public static byte[] serialize(){
TeacherSerializer.Teacher.Builder builder = TeacherSerializer.Teacher.newBuilder();
builder.setId(1001L)
.setAge(20)
.setName("liulaoshi")
.addCourses("java");
TeacherSerializer.Teacher teacher = builder.build();
byte[] bytes = teacher.toByteArray();
return bytes;
}
/**反序列化
*
* @param bytes
* @return
* @throws InvalidProtocolBufferException
*/
public static TeacherSerializer.Teacher deserialize(byte[] bytes) throws InvalidProtocolBufferException {
TeacherSerializer.Teacher teacher = TeacherSerializer.Teacher.parseFrom(bytes);
return teacher;
}
}
运行结果如下