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)
答案 0 :(得分:1)
根据我的MessagePack经验,它通常将对象视为MessagePack映射。
它不使用任何特定于语言的结构,因此它是跨平台的。
我认为您可能因为使用的库而遇到问题。你应该考虑官方的。您可以阅读更多相关信息here。它基本上是Jackson的一个扩展,让我们直接将Java对象串行化和反序列化到MessagePack中并且正在工作(至少在我必须使用它时)。