我正在使用https://github.com/allegro/json-avro-converter将我的 json 消息转换为 avro 文件。调用 convertToAvro 方法后,我得到一个字节数组:byte[] byteArrayJson。然后我使用 Apache 的公共库:
FileUtils.writeByteArrayToFile(myFile.avro, byteArrayJson);
文件已创建。当我尝试将其重新转换为 json 时,使用:
java -jar avro-tools-1.8.1.jar tojson myFile.avro > testCheck.json
Exception in thread "main" java.io.IOException: Not a data file.
at
org.apache.avro.file.DataFileStream.initialize(DataFileStream.java:105)
at org.apache.avro.file.DataFileStream.<init>(DataFileStream.java:84)
at org.apache.avro.tool.DataFileReadTool.run(DataFileReadTool.java:71)
at org.apache.avro.tool.Main.run(Main.java:87)
at org.apache.avro.tool.Main.main(Main.java:76)
我创建了一个 Junit 测试并使用 convertToJson 方法(来自上一个链接)并断言字符串,一切正常。但是对于罐子它不起作用。难道我做错了什么?我使用的是 cmd,而不是 powerShell,因为我在 SO 帖子中看到这可以更改编码。我认为问题出在编码上,但我不知道在哪里看。(我使用 Windows 作为操作系统)