使用Java计算BitTorrent info_hash

3

我正在尝试计算一个种子文件的 info_hash 值。我将整个种子文件读入到 StringBuffer 中,然后按照以下方式进行切割:

d8:announce...info[d6:length...e]e

我好像无法得到正确的哈希值。将种子文件读入 StringBuffer 会损坏字节数组末尾的字符串吗?我是否遗漏了什么?

public void calculateInfoHash( ){
try{
    int index = rawData.indexOf("4:info") + 6;
    int end = rawData.length() - 1;

    String info = rawData.substring( index , end );

    MessageDigest md = MessageDigest.getInstance( "SHA" );
    md.update( info.getBytes() );
    byte[] digest = md.digest();

    for ( byte b : digest ) {
    // print byte as 2 hex digits with lead 0. 
    //Separate pairs of digits with space
    //System.out.print( "%" );
    System.out.printf( "%02X", b & 0xff );
        }
    System.out.println( );

}catch( Exception e ) { 
    System.out.println( e.toString() );
}
}

1
根据你之前的问题,你已经得到了一个答案。我想知道那是什么,因为我也在尝试做同样的事情。 - BobMcGee
我解决这个问题的方法是在读取文件字节时计算哈希值。如果你将其读入字符串,然后再计算哈希值,它永远不会起作用,因为某些内容会被破坏。在解码器类中,当你从磁盘读取文件时进行计算。 - Hamza Yerlikaya
2个回答

1
我不知道在这种情况下正确的算法是什么,但从代码角度来看,每当您在字符串上调用getBytes()时,您应该始终指定一个字符集,否则它将使用系统默认值,这通常不是您想要的。请将其替换为:
md.update( info.getBytes("UTF-8") );

看看这是否有帮助。


-1
你可以下载Azureus的源代码,看看他们是如何实现的。

你好!你的链接从sourceforge.net重定向到vuze.com(Vuze Bittorrent客户端是免费软件,因此我找不到任何源代码)。谢谢! - eugenes
Azureus在许多年前更名为Vuze。他们同样在多年前关闭了源代码。 - OtherDevOpsGene

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接