Nie można wypisać poprawnego skrótu w Javie. Co jest nie tak?

W mojej aplikacji na Androida mam skrót SHA256, który muszę dalej mieszać za pomocą algorytmu skrótu wiadomości RIPEMD160.

Mogę wydrukować poprawny skrót sha256 i ripemd160 dowolnego ciągu, ale kiedy próbuję zahashować hash sha256 za pomocą ripemd160, otrzymuję hash, który jest niepoprawny.

Według kalkulatorów mieszania online wartość SHA256 ciągu „test” (wszystkie małe litery) to:

9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08

A wartość RIPEMD160 ciągu „test” to:

5e52fee47e6b070565f74372468cdc699de89107

Wartość mieszania haszowania sha256 za pomocą ripemd160 według obliczeń online to:

4efc1c36d3349189fb3486d2914f56e05d3e66f8

A moja aplikacja daje mi:

cebaa98c19807134434d107b0d3e5692a516ea66

co jest oczywiście błędne.

Oto mój kod:

public static String toRIPEMD160(String in)
{
    byte[] addr = in.getBytes();
    byte[] out = new byte[20];
    RIPEMD160Digest digest = new RIPEMD160Digest();
    byte[] sha256 = sha256(addr);
    digest.update(sha256,0,sha256.length);
    digest.doFinal(out,0);
    return getHexString(out);
}

public static byte[] sha256(byte[] data)
{
    byte[] sha256 = new byte[32];
    try
    {
        sha256 = MessageDigest.getInstance("SHA-256").digest(data);
    }
    catch(NoSuchAlgorithmException e)
    {}

    return sha256;
}

Dla algorytmu ripemd160 potrzebujesz bouncycastle i java.security.MessageDigest dla sha256.

questionAnswers(3)

yourAnswerToTheQuestion