最初にDBの結果を確認してください。最初のハッシュは、実際にはSHA-256ではなくSHA-224であるように見えます。
mysql> SELECT SHA2("A", 224);
+----------------------------------------------------------+
| SHA2("A", 224) |
+----------------------------------------------------------+
| 5cfe2cddbb9940fb4d8505e25ea77e763a0077693dbb01b1a6aa94f2 |
+----------------------------------------------------------+
1 row in set (0.00 sec)
それ以外の:
mysql> SELECT SHA2("A", 256);
+------------------------------------------------------------------+
| SHA2("A", 256) |
+------------------------------------------------------------------+
| 559aead08264d5795d3909718cdd05abd49572e84fe55590eef31a88a08fdffd |
+------------------------------------------------------------------+
1 row in set (0.06 sec)
そこから、正しい方向に進んでいます。byte[]出力を16進文字列に変換する必要があります。
import java.security.MessageDigest;
public class TestSHA256 {
public static void main(String[] args) {
try {
MessageDigest digest = MessageDigest.getInstance("SHA-256");
byte[] hash = digest.digest("A".getBytes("UTF-8"));
StringBuilder hexString = new StringBuilder();
for (int i: hash) {
hexString.append(Integer.toHexString(0XFF & i));
}
System.out.println(hexString);
} catch (Exception e) {
e.printStackTrace();
}
}
}
出力:
559aead08264d5795d399718cdd5abd49572e84fe55590eef31a88a08fdffd