美文网首页
MessagePack解析实例Java

MessagePack解析实例Java

作者: AioT_QJ | 来源:发表于2019-07-17 09:49 被阅读0次

一、MessagePack简介

MessagePack是更快,更小的数据传输格式,类似Json,支持多语言,比如Java ,C,C++ , 可以跨平台。比如可以用于Mqtt协议,在物联网和服务平台通讯中节省流量,提升效率。

二、Java两种加解包

方式一

数据格式

{
    "address":{
        "city":"广州",
        "street":"万达广场"
    },
    "sex":"男",
    "name":"张三",
    "age":31
}

maven引入依赖包

<dependency>
    <groupId>org.msgpack</groupId>
    <artifactId>msgpack</artifactId>
    <version>0.6.10</version>
</dependency>

数据压包

       Map<String,Object> userInfo = new HashMap<>();
        userInfo.put("name","张三");
        userInfo.put("age",31);
        userInfo.put("sex","男");
        Map<String,String> addr = new HashMap<>();
        addr.put("city","广州");
        addr.put("street","万达广场");
        userInfo.put("address",addr);
        System.out.println(JSON.toJSONString(userInfo));

        MessagePack messagePack = new MessagePack();
        
        byte[] data =  messagePack.write(userInfo);
        System.out.println(HexUtils.byte2hexString(data));

输出十六进制

84A76164647265737382A463697479A6E5B9BFE5B79EA6737472656574ACE4B887E8BEB
EE5B9BFE59CBAA3736578A3E794B7A46E616D65A6E5BCA0E4B889A36167651F

前两位含义:数字8代表Map类型,4代表有4个值

解包代码

 Map message = messagePack.read(data, 
                               Templates.tMap(Templates.TString,Templates.TValue));
 System.out.println(message);
//{name="张三", address={"city":"广州","street":"万达广场"}, age=31, sex="男"}

方式二

maven引入依赖包

<dependency>
    <groupId>org.msgpack</groupId>
    <artifactId>msgpack-core</artifactId>
    <version>0.8.17</version>
</dependency>

方式2代码

MessageBufferPacker packer = MessagePack.newDefaultBufferPacker();
       //数字类型
         packer.packInt(32);
      //字符类型
        packer.packString("李四");
        // arrays类型
        int[] arr = new int[] {4, 8, 1, 0, -7, 23};
        packer.packArrayHeader(arr.length);
        for (int v : arr) {
            packer.packInt(v);
        }
        // map类型
        packer.packMapHeader(2); 
        packer.packString("age");
        packer.packInt(1);
        packer.packString("sex");
        packer.packInt(2);

        //字节数组类型
        byte[] byteData = new byte[] {1, 2, 3, 4, 5, 6, 7};
        packer.packBinaryHeader(byteData.length);
        packer.writePayload(byteData );

        System.out.println(HexUtils.byte2hexString(packer.toByteArray()));
  
        //解包
        MessageUnpacker unpacker = 
               MessagePack.newDefaultUnpacker(packer.toByteArray());

        int age = unpacker.unpackInt();
        System.out.println(id);
        String name = unpacker.unpackString();
        System.out.println(name);

        int length = unpacker.unpackArrayHeader();
        int[] array = new int[length];
        for (int i = 0; i < length; ++i){
            array[i]=unpacker.unpackInt();
        }
        System.out.println(Arrays.toString(array));
       // 解析Map类型
        int maplen = unpacker.unpackMapHeader();
        for (int j = 0; j < maplen; j++) {
            System.out.println(unpacker.unpackString());
            System.out.println(unpacker.unpackInt());
        }
       //解析byte二进制类型
       int binaryLen = unpacker.unpackBinaryHeader();
        //按长度读取二进制数据
        byte[] bytes = new byte[binaryLen];
        unpacker.readPayload(bytes);
        System.out.println(Arrays.toString(bytes));


        packer.close();

总结

MessagePack的两种加解包方式可以灵活使用,第一种测试Map类型中有二进制类型,解析出来是乱码,可以通过第二种方式进行加解包解析。
通过jar中的丰富方法,可以灵活使用,是比Json更省流量的数据协议

相关文章

  • MessagePack解析实例Java

    一、MessagePack简介 MessagePack是更快,更小的数据传输格式,类似Json,支持多语言,比如J...

  • messagepack 的简单使用

    混淆################messagepack############### MessagePack ...

  • GraphQL Java从入门到实践

    源码解析 GraphQL Java 从Schema文件到GraphQL实例GraphQL Java 一次完整的执行...

  • java反射

    参考:深入解析Java反射(1) - 基础 获取class对象 判断是否某个类实例 创建实例 获取方法 getDe...

  • 对像和类

    Java 对象和类 多态 继承 封装抽象 Java对象和类 类对象实例方法消息解析代码: 11 运行结果: 小狗的...

  • Java 实例

    Java 环境设置实例 Java 实例 – 如何编译一个Java 文件? Java 实例 – Java 如何运行一...

  • java策略模式实例解析

    1、策略模式概述: 策略模式(Strategy Pattern):定义一系列算法,将每个算法封装起来,并让它们可以...

  • java状态模式实例解析

    状态模式是一种常用的设计模式,常用于软件系统中解决多种状态下行为互异的情况。例如在音视频播放器中多种状态各自对应着...

  • java 解析 xml 文件实例

    简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。 使用工具: SAXBuilder依赖: ...

  • java装饰模式实例解析

    1、装饰模式概述: 装饰模式(Decorator Pattern):动态地给一个对象增加一些额外的职责,就增加对象...

网友评论

      本文标题:MessagePack解析实例Java

      本文链接:https://www.haomeiwen.com/subject/sryflctx.html