3

info_hashトレントの価値を計算しようとしています。トレント全体を に読み込み、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() );
}
}
4

2 に答える 2

1

この場合の正しいアルゴリズムについてはわかりませんが、コードの観点からは、文字列で getBytes() を呼び出すときは常に文字セットを指定する必要があります。そうしないと、システムのデフォルトが使用されますが、これは多くの場合、必要なものではありません。それを次のように置き換えます。

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

そして、それが役立つかどうかを確認してください。

于 2009-06-18T20:40:14.497 に答える
-1

Azureusのソース コードを入手して、それがどのように行われるかを確認できます。

于 2009-06-18T20:36:58.717 に答える