Расчет bittorent info_hash с помощью Java - PullRequest
3 голосов
/ 19 июня 2009

Я пытаюсь вычислить значение 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 ]

1 голос
/ 19 июня 2009

Я не знаю о правильном алгоритме в этом случае, но с точки зрения кода всякий раз, когда вы вызываете getBytes () для String, вы всегда должны указывать набор символов, в противном случае он использует системное значение по умолчанию, которое часто не соответствует ты хочешь. Заменить его на:

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

и посмотрите, поможет ли это.

0 голосов
/ 19 июня 2009

Вы можете просто взять исходный код для Azureus и посмотреть, как они это делают.

...