3

我有以下跟踪器请求:

"info_hash=%92%c345%c0%28%15%e4rr%b1y%17%b7%cbs%0a%ef%9a%fc&peer_id=-UT2210-%2abP%b2%c23~NaN7-%7c%0f%1f&port=56541&uploaded=0&downloaded=0&left=461680&corrupt=0&key=6AD19369&event=started&numwant=200&compact=1&no_peer_id=1"

我想解码 JavaScript 中的info_hashandpeer_id字段。我尝试了unescape(),decodeURI()decodeURIComponent()函数,但它们没有返回预期的结果。

4

2 回答 2

6

对 Tracker 的 HTTP GET 请求中存在的信息哈希可以解码如下:

如果有一个 '%' 字符,那么接下来的 2 个字符是原始 40 char SHA-1 哈希的一部分。

因此,您可以按如下方式破坏编码的 info_hash:

%92 %c3 4 5 %c0 %28 %15 %e4 rr %b1 y %17 %b7 %cb s %0a %ef %9a %fc

所有以 '%' 符号为前缀的 2 个字符组都属于原始哈希。

现在,对于剩余的字符。我们需要找到它们对应的Hex值。您可以使用 asciitable 作为参考。

例如,以 10 为底的 4 是十六进制的 34。

以这种方式将所有内容组合在一起,我们得到:

92c33435c02815e47272b17917b7cb730aef9afc -> 种子文件的 SHA-1 哈希。

peer_id 将为我们提供有关客户端名称和版本的信息。在这种情况下:

-UT2210-%2abP%b2%c23~NaN7-%7c%0f%1f

这是 Azureus 格式。

UT 对应于 µTorrent,而 2210 为我们提供了版本。

解码过程可以很容易地使用 Perl 脚本自动化。

于 2011-11-09T11:37:03.077 回答
0

您用来“解码”的方法取决于它是如何“编码”的。

选择编码方式时:

escape() 不会编码:@*/+

encodeURI() 不会编码:~!@#$&*()=:/,;?+'

encodeURIComponent() 不会编码:~!*()'

您可能正在查看某种形式的双重编码。

于 2011-04-12T15:15:34.833 回答