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() );
}
}
4

2 回答 2

1

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

md.update( info.getBytes("UTF-8") );

看看是否有帮助。

于 2009-06-18T20:40:14.497 回答
-1

您可以获取Azureus的源代码,看看他们是如何做到的。

于 2009-06-18T20:36:58.717 回答