我正在尝试计算torrent的info_hash
值。我将整个torrent读入StringBuffer
,然后按以下方式剪切:
d8:announce...info[d6:length...e]e
我似乎无法获得正确的哈希值。将torrent写入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() );
}
}
答案 0 :(得分:1)
在这种情况下我不知道正确的算法,但从代码的角度来看,每当你在String上调用getBytes()时,你应该总是指定一个字符集,否则它会使用系统默认值,这通常不是什么你要。替换为:
md.update( info.getBytes("UTF-8") );
看看是否有帮助。
答案 1 :(得分:0)
您可以抓住Azureus的源代码,看看他们是如何做到的。