我正在尝试在 Android 中获取字符串的 SHA256。
这是我要匹配的 PHP 代码:
echo bin2hex(mhash(MHASH_SHA256,"asdf"));
//outputs "f0e4c2f76c58916ec258f246851bea091d14d4247a2fc3e18694461b1816e13b"
现在,在 Java 中,我正在尝试执行以下操作:
String password="asdf"
MessageDigest digest=null;
try {
digest = MessageDigest.getInstance("SHA-256");
} catch (NoSuchAlgorithmException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
digest.reset();
try {
Log.i("Eamorr",digest.digest(password.getBytes("UTF-8")).toString());
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
但这打印出来:“a42yzk3axdv3k4yh98g8”
我在这里做错了什么?
感谢埃里克森的解决方案:
Log.i("Eamorr",bin2hex(getHash("asdf")));
public byte[] getHash(String password) {
MessageDigest digest=null;
try {
digest = MessageDigest.getInstance("SHA-256");
} catch (NoSuchAlgorithmException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
digest.reset();
return digest.digest(password.getBytes());
}
static String bin2hex(byte[] data) {
return String.format("%0" + (data.length*2) + "X", new BigInteger(1, data));
}
原文由 Eamorr 发布,翻译遵循 CC BY-SA 4.0 许可协议
PHP 函数
bin2hex
意味着它接受一串字节并将其编码为十六进制数。在 Java 代码中,您尝试获取一堆随机字节并使用平台的默认字符编码将它们解码为字符串。那是行不通的,即使行得通,也不会产生相同的结果。
这是 Java 的快速二进制到十六进制转换:
这是 写得 快,执行起来不一定快。如果你正在做很多这样的事情,你应该用更快的实现来重写函数。