首页 > 其他分享 >网络传输数据序列化工具Protostuff

网络传输数据序列化工具Protostuff

时间:2022-09-02 20:58:44浏览次数:89  
标签:Protostuff return String private 传输数据 teachers new 序列化 public

  一直在物色比较好用的网络传输数据序列化工具,看了诸如marshalling,protobuff等,但是均有一个共同特点,使用起来异常繁杂,有没有比较好用同时性能又不会太差的组件呢?答案当然是有的,那就是基于protobuff改造的protostuff,它拥有良好性能的同时,又免去了生成描述文件的烦恼,可谓是趁手利器。

  来看看具体的使用方式吧。

  首先,引入maven依赖如下:

  

  io.protostuff

  protostuff-core

  1.4.4

  

  

  io.protostuff

  protostuff-runtime

  1.4.4

  

  之后,编写序列化工具Util:

  public class SerializeUtil {

  private static class SerializeData{

  private Object target;

  }

  @SuppressWarnings("unchecked")

  public static byte[] serialize(Object object) {

  SerializeData serializeData=new SerializeData();

  serializeData.target=object;

  Class serializeDataClass=(Class) serializeData.getClass();

  LinkedBuffer linkedBuffer=LinkedBuffer.allocate(1024 * 4);

  try {

  Schema schema=RuntimeSchema.getSchema(serializeDataClass);

  return ProtostuffIOUtil.toByteArray(serializeData, schema, linkedBuffer);

  } catch (Exception e) {

  throw new IllegalStateException(e.getMessage(), e);

  } finally {

  linkedBuffer.clear();

  }

  }

  @SuppressWarnings("unchecked")

  public static T deserialize(byte[] data, Class clazz) {

  try {

  Schema schema=RuntimeSchema.getSchema(SerializeData.class);

  SerializeData serializeData=schema.newMessage();

  ProtostuffIOUtil.mergeFrom(data, serializeData, schema);

  return (T) serializeData.target;

  } catch (Exception e) {

  throw new IllegalStateException(e.getMessage(), e);

  }

  }

  }

  需要注意的是RuntimeSchema.getSchema这块代码,通过翻看源码可以知道,里面已经放置了一个缓存map帮我们缓存生成的内容,所以不需要自己再加缓存了。

  由于protostuff目前不支持序列化list等对象,所以需要使用普通的POJO包装一下。

  最后,来写一个测试吧:

  public static void main(String...args) throws Exception {

  User user=new User();

  user.setUserId(123456);

  user.setAddress("I am a good boy");

  user.setNote("this is test");

  List list=new ArrayList<>();

  list.add("record1");

  list.add("record2");

  list.add("record3");

  user.setRecords(list);

  Teacher teacher1=new Teacher();

  teacher1.setName("语文老师");

  Teacher teacher2=new Teacher();

  teacher2.setName("数学老师");

  List teachers=new ArrayList<>();

  teachers.add(teacher1);

  teachers.add(teacher2);

  user.setTeachers(teachers);

  byte[] b=serialize(user);

  User rst=deserialize(b, User.class);

  System.out.println(JSON.toJSONString(rst));

  }

  class User {

  private Integer userId;

  private String address;

  private String note;

  private List records;

  private List teachers;

  public Integer getUserId() {

  return userId;

  }

  public void setUserId(Integer userId) {

  this.userId=userId;

  }

  public String getAddress() {

  return address;

  }

  public void setAddress(String address) {

  this.address=address;

  }

  public String getNote() {

  return note;

  }

  public void setNote(String note) {

  this.note=note;

  }

  public List getRecords() {

  return records;

  }

  public void setRecords(List records) {

  this.records=records;

  }

  public List getTeachers() {

  return teachers;

  }

  public void setTeachers(List teachers) {

  this.teachers=teachers;

  }

  }

  class Teacher{

  private String name;

  public String getName() {

  return name;

  }

  public void setName(String name) {

  this.name=name;

  }

  }

  最终的运行结果如下:

  {"address":"I am a good boy","note":"this is test","records":["record1","record2","record3"],"teachers":[{"name":"语文老师"},{"name":"数学老师"}],"userId":123456}

  可以看到,这种相对来说比较复杂的结构的序列化和反序列化,还是挺得心应手的。

标签:Protostuff,return,String,private,传输数据,teachers,new,序列化,public
From: https://www.cnblogs.com/ebuybay/p/16651180.html

相关文章

  • Java中具有继承的对象序列化
    在序列化中,当引入继承时,则根据超类和子类定义了某些情况,这使对每种情况下的序列化的理解变得更加简单。应遵循的基本规则如下。1.当超类实现时,可序列化接口而子类则不。......
  • Flask 学习-38.Flask-RESTful 序列化输出中文显示问题
    前言flask接口无法显示中文,可以添加全局配置JSON_AS_ASCII=False,但是解决不了Flask-RESTful序列化输出中文问题flask配置中文显示添加全局配置项JSON_AS_ASCII=Fa......
  • 使用 CerealBox 将 AWS DynamoDB JSON 序列化为 Python dict
    使用CerealBox将AWSDynamoDBJSON序列化为Pythondict在这里,我们讨论了一个快速演练和参考代码,用于为您的下一个AWS应用程序简化DynamoDBJSON序列化过程。绒......
  • 模型类序列化器的声明和操作使用
    ModelSerializer与常规的Serializer相同,但额外提供了:·基于模型类自动生成一系列字段·基于模型类自动为Serializer生成validators,比如unique_together·包含默认的cre......
  • 序列化器:反序列换-添加和更新数据操作
    前端传到后端需要反序列化,后端传到前端需要序列化正常需要serializer两次:fromdjango.viewsimportViewfrom.modelsimportStudentfrom.serializersimportStude......
  • [网鼎杯 2020 朱雀组]phpweb-1|反序列化
    1、打开界面之后界面一直在刷新,检查源代码也未发现提示信息,但是在检查中发现了两个隐藏的属性:func和p,抓包进行查看一下,结果如下:2、对两个参数与返回值进行分析,我们使用d......
  • 序列化器:反序列换-字段选项 validate validate_<字段> validator
    1.使用序列化器进行反序列化时,需要对数据进行验证后,才能获取验证成功的数据或保存成模型类对象。2.在获取反序列化的数据前,必须调用is_valid()方法进行验证,验证成功返回Tr......
  • 序列化器:序列化一个模型对象和多个模型对象
    1.序列化,序列化器会把模型对象转换成字典,经过response以后变成json字符串2.反序列化,把客户端发送过来的数据,经过request以后变成字典,序列化器可以把字典转成模型......
  • 序列化与反序列化
    1.参与序列化的对象必须实现Serializable接口,起到相应的标识作用,Java虚拟机会给该类自动生成一个序列化版本号2.java通过类名+序列化版本号的方式进行区分,transient关......
  • [CISCN2019 华北赛区 Day1 Web2]ikun-1|python反序列化
    考点:JWT身份伪造、pythonpickle反序列化、逻辑漏洞1、打开之后首页界面直接看到了提示信息,信息如下:2、那就随便注册一个账号进行登录,然后购买lv6,但是未发现lv6,那就查看......