MessagePack Java 序列化为数组

MessagePack Java serializing as array

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

这是什么宇宙"like JSON"?

我的情况: 我有一个简单的 class 像这样:

@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)

从我的MessagePack经验来看,它通常把对象当作MessagePack映射。

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

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