Java阅读文章,奇怪的十六进制解释
我试图让我的Go服务器向我的Java应用程序发送带有字节数组的POST请求 原始数据字节如下所示(添加了行制动器): 我在Java中收到的信息如下所示:Java阅读文章,奇怪的十六进制解释,java,http,post,hex,go,Java,Http,Post,Hex,Go,我试图让我的Go服务器向我的Java应用程序发送带有字节数组的POST请求 原始数据字节如下所示(添加了行制动器): 我在Java中收到的信息如下所示: 2D9F8B52044 76657273696F6E000000000055000000 C856CDEB40FA0000010000000000000009A33A94E 00000000010000000000000000000000000000000000 2C72C76D7B7413147F90100000000000000000000
2D9F8B52044
76657273696F6E000000000055000000
C856CDEB40FA0000010000000000000009A33A94E
00000000010000000000000000000000000000000000
2C72C76D7B7413147F9010000000000000000000000000000000000
2C72C75120AC482647F920AB4678B620194D4E0001000000
0000 50 4f 53 54 20 2f 68 61 6e 64 6c 65 70 6f 73 74 POST /handlepost
0010 20 48 54 54 50 2f 31 2e 31 0d 0a 43 6f 6e 74 65 HTTP/1.1..Conte
0020 6e 74 2d 54 79 70 65 3a 20 0d 0a 48 6f 73 74 3a nt-Type: ..Host:
0030 20 6c 6f 63 61 6c 68 6f 73 74 3a 38 30 38 30 0d localhost:8080.
0040 0a 43 6f 6e 74 65 6e 74 2d 4c 65 6e 67 74 68 3a .Content-Length:
0050 20 31 30 39 0d 0a 41 63 63 65 70 74 2d 45 6e 63 109..Accept-Enc
0060 6f 64 69 6e 67 3a 20 67 7a 69 70 0d 0a 55 73 65 oding: gzip..Use
0070 72 2d 41 67 65 6e 74 3a 20 41 70 70 45 6e 67 69 r-Agent: AppEngi
0080 6e 65 2d 47 6f 6f 67 6c 65 3b 20 28 2b 68 74 74 ne-Google; (+htt
0090 70 3a 2f 2f 63 6f 64 65 2e 67 6f 6f 67 6c 65 2e p://code.google.
00a0 63 6f 6d 2f 61 70 70 65 6e 67 69 6e 65 29 0d 0a com/appengine)..
00b0 0d 0a fa bf b5 da 76 65 72 73 69 6f 6e 00 00 00 ......version...
00c0 00 00 55 00 00 00 e9 56 ea 91 40 9c 00 00 01 00 ..U....V..@.....
00d0 00 00 00 00 00 00 09 a3 bd 4e 00 00 00 00 01 00 .........N......
00e0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
00f0 ff ff 6d 7b 74 f5 47 9d 01 00 00 00 00 00 00 00 ..m{t.G.........
0100 00 00 00 00 00 00 00 00 00 00 ff ff 51 db 48 26 ............Q.H&
0110 47 9d 20 c7 46 78 a6 d5 4d 4e 00 01 00 00 00 G. .Fx..MN.....
我尝试将数据发布到我的Go应用程序的另一个功能中,它运行良好
作为Java应用程序的基础,我使用了
它被修改以处理POST请求。在使用input.readLine()清除HTTP请求的前几行之后,我使用以下命令读取数据:
int hex=0;
while((hex=input.read())>-1){
System.out.printf("%02X", hex);
}
Wireshark的十六进制转储看起来像:
2D9F8B52044
76657273696F6E000000000055000000
C856CDEB40FA0000010000000000000009A33A94E
00000000010000000000000000000000000000000000
2C72C76D7B7413147F9010000000000000000000000000000000000
2C72C75120AC482647F920AB4678B620194D4E0001000000
0000 50 4f 53 54 20 2f 68 61 6e 64 6c 65 70 6f 73 74 POST /handlepost
0010 20 48 54 54 50 2f 31 2e 31 0d 0a 43 6f 6e 74 65 HTTP/1.1..Conte
0020 6e 74 2d 54 79 70 65 3a 20 0d 0a 48 6f 73 74 3a nt-Type: ..Host:
0030 20 6c 6f 63 61 6c 68 6f 73 74 3a 38 30 38 30 0d localhost:8080.
0040 0a 43 6f 6e 74 65 6e 74 2d 4c 65 6e 67 74 68 3a .Content-Length:
0050 20 31 30 39 0d 0a 41 63 63 65 70 74 2d 45 6e 63 109..Accept-Enc
0060 6f 64 69 6e 67 3a 20 67 7a 69 70 0d 0a 55 73 65 oding: gzip..Use
0070 72 2d 41 67 65 6e 74 3a 20 41 70 70 45 6e 67 69 r-Agent: AppEngi
0080 6e 65 2d 47 6f 6f 67 6c 65 3b 20 28 2b 68 74 74 ne-Google; (+htt
0090 70 3a 2f 2f 63 6f 64 65 2e 67 6f 6f 67 6c 65 2e p://code.google.
00a0 63 6f 6d 2f 61 70 70 65 6e 67 69 6e 65 29 0d 0a com/appengine)..
00b0 0d 0a fa bf b5 da 76 65 72 73 69 6f 6e 00 00 00 ......version...
00c0 00 00 55 00 00 00 e9 56 ea 91 40 9c 00 00 01 00 ..U....V..@.....
00d0 00 00 00 00 00 00 09 a3 bd 4e 00 00 00 00 01 00 .........N......
00e0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
00f0 ff ff 6d 7b 74 f5 47 9d 01 00 00 00 00 00 00 00 ..m{t.G.........
0100 00 00 00 00 00 00 00 00 00 00 ff ff 51 db 48 26 ............Q.H&
0110 47 9d 20 c7 46 78 a6 d5 4d 4e 00 01 00 00 00 G. .Fx..MN.....
如何正确读取这些字节?问题在于:
BufferedReader input =
new BufferedReader(new InputStreamReader(connectionsocket.
getInputStream()));
InputStreamReader
必须将字节转换为字符,而您并没有告诉它如何进行转换,或者,换句话说,您是含蓄地告诉它使用平台的默认字符集。对于ASCII范围(00
到7F
)内的字节,这似乎可以正常工作,但在该范围外的字节上会出现中断
您的应用程序似乎正在发送二进制数据(我指的是非文本数据);您应该将其更改为以文本形式对所有内容进行编码,或者不使用InputStreamReader
。(不幸的是,这使得处理标题行变得有点棘手,因为您不能再使用BufferedReader.readLine()
)问题(或问题)就在这里:
BufferedReader input =
new BufferedReader(new InputStreamReader(connectionsocket.
getInputStream()));
InputStreamReader
必须将字节转换为字符,而您并没有告诉它如何进行转换,或者,换句话说,您是含蓄地告诉它使用平台的默认字符集。对于ASCII范围(00
到7F
)内的字节,这似乎可以正常工作,但在该范围外的字节上会出现中断
您的应用程序似乎正在发送二进制数据(我指的是非文本数据);您应该将其更改为以文本形式对所有内容进行编码,或者不使用
InputStreamReader
。(不幸的是,这使得处理标题行变得有点棘手,因为您不能再使用BufferedReader.readLine()
)如何获取输入流?如果您必须编写代码来跳过标题,那么我猜您没有使用HttpURLConnection或其他库。在这种情况下,您可能会看到来自分块传输编码的额外位
您是如何获得输入流的?如果您必须编写代码来跳过标题,那么我猜您没有使用HttpURLConnection或其他库。在这种情况下,您可能会看到来自分块传输编码的额外位
您是否尝试过使用Wireshark或类似工具查看数据在线路上的外观?您的Go代码是什么样子的?我不认为Go服务器使用十六进制作为ascii发送。只需使用read(…)@JonSkeet添加了Wireshark转储示例。您是否尝试过使用Wireshark或类似工具来查看数据在电线上的外观?您的Go代码是什么样子的?我不认为Go服务器使用十六进制作为ascii发送。只需使用read(…)@JonSkeet添加了Wireshark转储示例。绝对不是分块传输编码;Wireshark输出清楚地显示
内容长度:109
,而不是传输编码:chunked
,而且无论如何,chunked传输编码只会添加字节,不会删除字节。绝对不是chunked传输编码;Wireshark输出清楚地显示内容长度:109
,而不是传输编码:chunked
,无论如何,chunked传输编码只会添加字节,不会删除字节。感谢您的输入,在努力使用不同的类读取数据之后,由于您的洞察力,我终于能够让代码正常工作。感谢您的输入,在努力使用不同的类读取数据之后,由于您的洞察力,我终于能够让代码正常工作。