解析这个HTTP包里的content内容参数

这个是我用【Charles4.2.1】抓到的百词斩APP的查词请求:
https://pan.baidu.com/s/18hIuHHmcjYrF6_7_mVjQqw

我最终的目的是用代码模拟POST和GET请求,获得所要查的单词的资源。
我发现POST包中content包含的查词指令可以直接看到,但是包含有乱码,并且GET包中获得的content也有乱码。
请问该如何解决乱码问题,并实现用代码直接向网络查词??

(另外我猜测链接最后的13位数字是时间信息--“15222...”开头的)

猜测百词斩内部极有可能使用byte接受content内容的,里面包含控制字段,随便拿了你抓包的内容。
第一个包的内容单独用utf8去看。

 n. 字母 用以构成家名、店名等;用以构成单数名词或不以s结尾的复数名词的所有格]表示

大致能看到内容,其中其他的东西,应该是控制,比如EF BF用来控制结束什么的。

所以你get和post的时候,需要用bytes去存储content,然后再根据一定的协议增加占位符,

比如他的请求,前四位应该是顺序号
00 00 00 17 然后顺序累加,82 21 01 0E 是报文头,然后后面是search_w 表示请求。然后是ord_v2,之后是18分隔符,下一位是单词长度,后面n位是单词,最后00结尾。

然后152那个确实是时间,是时间戳,从 1970/01/01 至今已过去 1523291937000 毫秒,这是当前的时间戳。一般unit的要准一点,应该是纯粹为了防止重复请求缓存的

https://blog.csdn.net/blueheart20/article/details/45174399

有思路了,匆匆试了下POST包,得到这样的结果(T▽T),还要再调调直接用HEX的部分。。。
图片说明

在书上看到堆中有一个叫永久代的地方,里面是存放类,静态变量,方法的地方。 然而又在书中看到一个地方叫方法区,也是存放类,静态变量,方法的地方。 2者是否 相同?还是说我理解错里。

回复:q447552640
(1)00 00 00 17 中实质是15 加上单词的长度,其他都没有错。
(2)把param用writeBytes输出去 会出现代码语法约束错误(类型不对),所以我用了另一种方法。
(3)POST包的Cookie中, 必须包含“access_token”参数才能响应到正确数据。
遇到的问题:
当我把POST的相应数据得到后,怎么都不能用UTF-8来显示,我代码中处理得到的是一团乱码(正常的英文字符都编乱码了),但可以通过Charles抓包查看确定响应的数据是正确的,所以问题就出在我自己用代码处理上。。。请问有没有办法修正一下我的代码??

new Thread(new Runnable(){
    public void run() {
        try {
            String path = "http://resource.baicizhan.org/rpc/resource_api/search_word_v2/" + System.currentTimeMillis();
            HttpURLConnection conn = (HttpURLConnection) new URL(path).openConnection();
            conn.setConnectTimeout(5000);
            conn.setRequestMethod("POST");
            conn.setRequestProperty("Content-Type","application/x-thrift");
            conn.setRequestProperty("Accept","application/x-thrift");
            conn.setRequestProperty("User-Agent","bcz_app/android/6.2.13");
            conn.setRequestProperty("Accept-Encoding","gzip, deflate, sdch");
            conn.setRequestProperty("Compress-Type","plain");
            conn.setRequestProperty("Cookie","access_token=MR8Sotb9bIzQYdNbY2OS7HuS9Nq+9bB1cWTMaacOrI0=;");
            conn.setRequestProperty("Connection","Keep-Alive");

            byte param0[] = {0x00,0x00,0x00};
            byte param1[] = {(byte) 0x82,0x21,0x01,0x0e,0x73,0x65,0x61,0x72,0x63,0x68,0x5f,
                    0x77,0x6f,0x72,0x64,0x5f,0x76,0x32,0x18};
            OutputStream dos = new DataOutputStream(conn.getOutputStream());

            String word = "stop";
            byte length = Byte.parseByte(Integer.toHexString(word.length()));
            dos.write(param0);
            dos.write(0x15 + length);
            dos.write(param1);
            dos.write(length);
            dos.write(word.getBytes());
            dos.write(0x00);
            dos.flush();
            dos.close();

            if(conn.getResponseCode() == 200){
                StringBuilder sb = new StringBuilder();
                String readLine;
                BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream(),"UTF-8"));
                while((readLine = br.readLine()) != null){
                    sb.append(readLine).append("\n");
                }
                br.close();
                System.out.println(sb.toString());
            }
        }  catch (Exception e) {
            e.printStackTrace();
        }
    }
}).start();

图片说明