Расчет битторента info_hash с помощью Java
Я пытаюсь вычислить 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() );
}
}
2 ответа
Я не знаю о правильном алгоритме в этом случае, но с точки зрения кода всякий раз, когда вы вызываете getBytes() для String, вы всегда должны указывать набор символов, в противном случае он использует системное значение по умолчанию, которое часто не то, что вы хотите. Заменить его на:
md.update( info.getBytes("UTF-8") );
и посмотрим, поможет ли это.
Вы можете просто взять исходный код для Azureus и посмотреть, как они это делают.