我用Python编写了一个原型,因为我知道它应该是什么样子。与结构包,它将打包数据,并且您可以指定它以网络字节顺序(Big-Endian)执行此操作。这是我编写的原型(它与服务器一起工作)。在
5 def _BuildPDUToTx(pduObj):
6 txData = struct.pack('!i i', pduObj.Src.Type, pduObj.Src.Len) #pduObj.Src.Type: 1
#pduObj.Src.Len: 16
7 txData += pduObj.Src.Value #pduObj.Src.Value: sourceid
8 txData += struct.pack('!i i', pduObj.Dst.Type, pduObj.Dst.Len) #pduObj.Dst.Type: 2
#pduObj.Dst.Len: 14
9 txData += pduObj.Dst.Value #pduObj.Dst.Value: destid
10 txData += struct.pack('!i i i i', pduObj.Metadata.Type, pduObj.Metadata.Len,\ #pduObj.Metadata.Type: 3
11 pduObj.Metadata.Status, pduObj.Metadata.Remaining) #pduObj.Metadata.Len: 16
#pduObj.Metadata.Status: 0
#pduObj.Metadata.Remaining: 0
12 txData += struct.pack('!i i', pduObj.Msg.Type, pduObj.Msg.Len) #pduObj.Msg.Type: 6
#pduObj.Msg.Len: 27
13 txData += pduObj.Msg.Value #pduObj.Msg.Value: This is the message
14 return(txData)
我用一些示例代码运行它(示例值是侧面的注释),如果在服务器端设置一个原始的netcat侦听器(只想看看数据是什么样子的),就会得到以下结果。在
^{pr2}$我也尝试过这样做(并使用了Java equivalent of Python's struct.pack?和{a2}的建议)。在
我使用了以下代码:
client = new Socket(server, port);
ObjectOutputStream dos = new ObjectOutputStream(new BufferedOutputStream(client.getOutputStream()));
ByteBuffer buffer = ByteBuffer.allocate(1000);
dos.writeInt(Src.Type); // int value 1
dos.writeInt(Src.Len); // int value 16
dos.writeUTF(Src.Value); // String value "sourceid"
dos.writeInt(Dst.Type); // int value 2
dos.writeInt(Dst.Len); // int value 14
dos.writeUTF(Dst.Value); // String value "destid"
dos.writeInt(Metadata.Type); // int value 3
dos.writeInt(Metadata.Len); // int value 16
dos.writeInt(Metadata.Status); // int value 0
dos.writeInt(Metadata.Remaining); // int value 0
dos.writeInt(Msg.Type); // int value 6
dos.writeInt(Msg.Len); // int value 27
dos.writeUTF(Msg.Value); // String value "this is the message"
dos.flush();
InputStream is = client.getInputStream();
byte[] buf = new byte[Constants.ResponseSize];
is.read(buf, 0, Constants.ResponseSize);
client.close();
然而,我得到了如下结论。在
0000000 edac 0500 4f77 0000 0100 0000 1000 0800
0000010 [6f73 7275 6563 6469] 0000 0200 0000 0e00 *brackets have "sourceid"
0000020 0600 [6564 7473 6469] 0000 0300 0000 1000 *brackets have "destid"
0000030 0000 0000 0000 0000 0000 0600 0000 1b00
0000040 1300 [6854 7369 6920 2073 6874 2065 656d *brackets have "This is the message"
0000050 7373 6761 0065]
0000055
Java似乎增加了不少额外的功能。就像前两个字节和我放在流里的任何东西都不一样。后面是我的值1(32位)和16(下一个32位),但是在“sourceid”之前有0800。在
Java到底在干什么??我怎样才能让它更像python呢?在
使用DataOutputStream,而不是ObjectOutputStream。在
ObjectOutputStream用于将Java对象从一个JVM发送到另一个JVM,主要由Java对象序列化框架使用。在
DataOutputStream用Big-Endian写入所有内容。在
但是,使用
writeUTF
时可能需要小心。根据规范,它预先设置字节序列的长度。这可能是你想要的,也可能不是。在相关问题 更多 >
编程相关推荐