我正在使用此函数来计算SHA 256
public static String getSHA1(String plainText) {
MessageDigest md;
try {
md = MessageDigest.getInstance("SHA-256");
md.update(plainText.getBytes(Charset.forName("UTF-8")));
StringBuffer hexString = new StringBuffer();
byte[] bytes = md.digest();
for (int i = 0; i < bytes.length; i++) {
hexString.append(Integer.toHexString(0xFF & bytes[i]));
}
return hexString.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
}
为了确定我的结果,我查看了这个在线网站 http://onlinemd5.com/
我的代码与在线之间的结果几乎相同,但您知道它必须是equal
。例如
1234567
8BB0CF6EB9B17D0F7D22B456F121257DC1254E1F01665370476383EA776DF414
8bb0cf6eb9b17df7d22b456f121257dc1254e1f1665370476383ea776df414
这是更多的例子:
7777777
8C1CDB9CB4DBAC6DBB6EBD118EC8F9523D22E4E4CB8CC9DF5F7E1E499BBA3C10
8c1cdb9cb4dbac6dbb6ebd118ec8f9523d22e4e4cb8cc9df5f7e1e499bba3c10
147258
7A2EC40FF8A1247C532309355F798A779E00ACFF579C63EEC3636FFB2902C1AC
7a2ec4ff8a1247c53239355f798a779e0acff579c63eec3636ffb292c1ac
888888
92925488B28AB12584AC8FCAA8A27A0F497B2C62940C8F4FBC8EF19EBC87C43E
92925488b28ab12584ac8fcaa8a27af497b2c6294c8f4fbc8ef19ebc87c43e
我知道这是关于编码的maybe
。但看起来我用utf-8
这是网站使用的
答案 0 :(得分:3)
这是问题所在:
hexString.append(Integer.toHexString(0xFF & bytes[i]));
这将丢失任何前导0 - 换句话说,任何小于16的字节将作为单个十六进制数而不是两个。
有很多修复方法。例如:
0
String.format("%02x", bytes[i] & 0xff)