Java阅读POST,奇怪的十六进制解释

时间:2011-11-11 22:18:53

标签: java http post hex go

我试图让我的Go服务器向我的Java应用程序发送带有字节数组的POST请求。

原始数据字节看起来像(添加了行刹车):

FABFB5DA
76657273696F6E000000000055000000
67C4256E409C0000010000000000000013A3BD4E
00000000010000000000000000000000000000000000
FFFF6D7B74F5479D010000000000000000000000000000000000
FFFF51DB4826479D59128BC986A833460001000000

我在Java中收到的内容如下:

2D9F8B52044
76657273696F6E000000000055000000
C856CDEB40FA0000010000000000000009A33A94E
00000000010000000000000000000000000000000000
2C72C76D7B7413147F9010000000000000000000000000000000000
2C72C75120AC482647F920AB4678B620194D4E0001000000

我尝试将数据发布到我的Go应用程序的另一个函数,它工作正常。

作为我的Java应用程序的基础,我使用了代码 http://fragments.turtlemeat.com/javawebserver.php

更改它以处理POST请求。在用input.readLine()清除前几行HTTP请求之后,我用以下内容读取数据:

int hex=0;
while((hex=input.read())>-1){
System.out.printf("%02X", hex);
}

Wireshark的十六进制转储如下:

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.....

我应该如何正确阅读这些字节?

2 个答案:

答案 0 :(得分:4)

问题 - 或 问题 - 就在这一点:

    BufferedReader input =
        new BufferedReader(new InputStreamReader(connectionsocket.
        getInputStream()));

InputStreamReader必须从字节转换为字符,而你并没有告诉它如何做到这一点 - 或者换句话说,你隐含地告诉它使用你平台的默认字符集。这似乎适用于ASCII范围(007F)中的字节,但会破坏该范围之外的字节。

您的应用程序似乎正在发送二进制数据(我指的是非文本数据);您应该更改它以文本形式编码所有内容,否则不要使用InputStreamReader。 (不幸的是,这使得处理标题行变得有点棘手,因为你不能再使用BufferedReader.readLine()了。)

答案 1 :(得分:0)

您是如何获得输入流的?如果你必须编写代码来跳过标题,那么我猜你没有使用HttpURLConnection或其他一些库。在这种情况下,您可能会从分块传输编码中查看额外的位。

https://en.wikipedia.org/wiki/Chunked_transfer_encoding