Строка хеша через SHA-256 в Java - PullRequest
106 голосов
/ 23 июня 2010

Просматривая здесь, а также в Интернете в целом, я нашел Надувной замок . Я хочу использовать Bouncy Castle (или другую бесплатную утилиту) для генерации SHA-256 хеша строки в Java. Глядя на их документацию, я не могу найти хороших примеров того, что я хочу сделать. Кто-нибудь может мне здесь помочь?

Ответы [ 8 ]

250 голосов
/ 23 июня 2010

Для хеширования строки используйте встроенный MessageDigest class:

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.nio.charset.StandardCharsets;
import java.math.BigInteger;

public class CryptoHash {
  public static void main(String[] args) throws NoSuchAlgorithmException {
    MessageDigest md = MessageDigest.getInstance("SHA-256");
    String text = "Text to hash, cryptographically.";

    // Change this to UTF-16 if needed
    md.update(text.getBytes(StandardCharsets.UTF_8));
    byte[] digest = md.digest();

    String hex = String.format("%064x", new BigInteger(1, digest));
    System.out.println(hex);
  }
}

В приведенном выше фрагменте digest содержит хешированную строку, а hex содержит шестнадцатеричноеСтрока ASCII с дополнением нулями слева.

28 голосов
/ 23 июня 2010

Это уже реализовано в библиотеках времени выполнения.

public static String calc(InputStream is) {
    String output;
    int read;
    byte[] buffer = new byte[8192];

    try {
        MessageDigest digest = MessageDigest.getInstance("SHA-256");
        while ((read = is.read(buffer)) > 0) {
            digest.update(buffer, 0, read);
        }
        byte[] hash = digest.digest();
        BigInteger bigInt = new BigInteger(1, hash);
        output = bigInt.toString(16);
        while ( output.length() < 32 ) {
            output = "0"+output;
        }
    } 
    catch (Exception e) {
        e.printStackTrace(System.err);
        return null;
    }

    return output;
}

В среде JEE6 + можно также использовать JAXB DataTypeConverter :

import javax.xml.bind.DatatypeConverter;

String hash = DatatypeConverter.printHexBinary( 
           MessageDigest.getInstance("MD5").digest("SOMESTRING".getBytes("UTF-8")));
16 голосов
/ 11 августа 2014

Вам не обязательно нужна библиотека BouncyCastle. Следующий код показывает, как это сделать, используя функцию Integer.toHexString

public static String sha256(String base) {
    try{
        MessageDigest digest = MessageDigest.getInstance("SHA-256");
        byte[] hash = digest.digest(base.getBytes("UTF-8"));
        StringBuffer hexString = new StringBuffer();

        for (int i = 0; i < hash.length; i++) {
            String hex = Integer.toHexString(0xff & hash[i]);
            if(hex.length() == 1) hexString.append('0');
            hexString.append(hex);
        }

        return hexString.toString();
    } catch(Exception ex){
       throw new RuntimeException(ex);
    }
}

Отдельное спасибо user1452273 из этого поста: Как хэшировать строку с sha256 в Java?

Продолжайте в том же духе!

8 голосов
/ 23 июня 2010

При использовании хеш-кодов с любым провайдером jce вы сначала пытаетесь получить экземпляр алгоритма, затем обновите его данными, которые вы хотите хэшировать и когда вы закончите, вы вызываете digest, чтобы получить значение хеша.

MessageDigest sha = MessageDigest.getInstance("SHA-256");
sha.update(in.getBytes());
byte[] digest = sha.digest();

вы можете использовать дайджест, чтобы получить версию с кодировкой base64 или hex в соответствии с вашими потребностями

7 голосов
/ 19 июля 2015

Java 8: Base64 доступно:

    MessageDigest md = MessageDigest.getInstance( "SHA-512" );
    md.update( inbytes );
    byte[] aMessageDigest = md.digest();

    String outEncoded = Base64.getEncoder().encodeToString( aMessageDigest );
    return( outEncoded );
5 голосов
/ 29 ноября 2012

Полагаю, вы используете относительно старую версию Java без SHA-256. Поэтому вы должны добавить провайдера BouncyCastle к уже предоставленным «провайдерам безопасности» в вашей java-версии.

    // NEEDED if you are using a Java version without SHA-256    
    Security.addProvider(new BouncyCastleProvider());

    // then go as usual 
    MessageDigest md = MessageDigest.getInstance("SHA-256");
    String text = "my string...";
    md.update(text.getBytes("UTF-8")); // or UTF-16 if needed
    byte[] digest = md.digest();
1 голос
/ 22 декабря 2010
return new String(Hex.encode(digest));
0 голосов
/ 07 июля 2014

Это будет работать с "org.bouncycastle.util.encoders.Hex" следующего пакета

return new String(Hex.encode(digest));

В баночке для накала.

...