admin管理员组

文章数量:1606473

前提上次说明了findnode的编码,就可以发送find_node的信息了

现在进行find_node的返回包进行解析

获取的字节信息不能直接转化为String然后在根据Bencode规则解码,这样获取的数据是乱码

类型数组使用d开头e结尾 d在ascill中是100,也就是说遇到100开头的就表明是数组

整数使用i开头e结尾 i在ascill中是105,遇到105表示整数

列表List使用l表示 在ascill中是108 相同遇到108表示列表

48-57之间表示数字对于的是String字符串

find_node 返回的是其他节点信息1、首先返回值一定是一个数组 也就是一定是d开头e结尾,如果不是的,直接按解码错误处理

2、然后获取下一个数据,查看在ascill中对应的是什么

3、根据对于的值(48-57,108,105,100)来判断解码的方式

4、在48-57之间表示是字符串,继续获取下一个字符直到获取到58也就是冒号,前面保存的就是后面String的长度了,继续获取String的长度的字符的byte数组保存 -- 解码(String解码)

5、如果是 100 表示里面还是一个数组,再次调用自身的方法。 -- 解码(map解码)

6、如果是105 表示是一个整数,继续获取下去,直到101 也就是e结束,注意有可能会出现‘.’号的情况,返回一个整数或者小数即可 -- 解码(整数解码)

7、如果是108 表示集合,再次调用自身方法 -- 解码(list解码)

获取的信息保存在map中,以String-Object的形式保存。

后续对map进行解析

本文标签: 磁力链接数据Java