MessagePack Java序列化为数组

时间:2016-03-10 15:57:25

标签: java json messagepack

Java中的MessagePack官方实现将公共字段序列化为数组是否被接受?

这个“像JSON”的宇宙是什么?

我的情况: 我有一个简单的类:

@Message
public class MySuperClass(){
    public int mySuperID; // let's say 4
    public byte[] mySuperData; // let's say nothing
    public String mySuperType; // let's say null
    public String mySuperExtra; // let's say HI!

    public MySuperClass(){}

    // other constructors
}

我只是用

序列化
MessagePack msgpack = new MessagePack();
msgpack.write(mySuperInstance);

将其发送到用NodeJS编写的远程服务器。

Node JS可以轻松解压缩到

['HI!', �, 4, null]

这意味着MessagePack与JSON完全不同,因为它将Java对象解析为数组,然后只按字母顺序重新填充它们!

有没有人有一个解决方案,不包括映射我拥有的每个对象? (此外,HashMap不能被Node解包,这意味着messagePack不是跨平台的,因此,重复,注意像JSON)

1 个答案:

答案 0 :(得分:1)

根据我的MessagePack经验,它通常将对象视为MessagePack映射。

它不使用任何特定于语言的结构,因此它是跨平台的。

我认为您可能因为使用的库而遇到问题。你应该考虑官方的。您可以阅读更多相关信息here。它基本上是Jackson的一个扩展,让我们直接将Java对象串行化和反序列化到MessagePack中并且正在工作(至少在我必须使用它时)。