Java的MessageDigest SHA1算法返回的结果与php的SHA1函数不同

我有一个带有用户名和密码的SQL表.密码使用MessageDigest的digest()方法进行编码.如果我编码一个密码 – 让我们说“abcdef12” – 使用MessageDigest的digest()方法然后将其转换为十六进制值,则String与使用PHP的SHA1方法执行相同操作时不同.我希望这些值完全相同.

用于对密码进行编码的代码:

MessageDigest md = MessageDigest.getInstance("SHA-1");
byte[] passbyte;
passbyte = "abcdef12".getBytes("UTF-8");
passbyte = md.digest(passbyte);

使用此方法将String转换为十六进制:

public static String convertStringToHex(String str) {

    char[] chars = str.toCharArray();

    StringBuffer hex = new StringBuffer();
    for (int i = 0; i < chars.length; i++) {
        hex.append(Integer.toHexString((int) chars[i]));
    }

    return hex.toString();
}

密码:abcdef12

这是许多SHA1-hash在线生成器和PHP SHA1()返回的密码 – 功能:d253e3bd69ce1e7ce6074345fd5faa1a3c2e89ef

这是MessageDigest编码的密码:d253e3bd69ce1e7ce674345fd5faa1a3c2e2030ef

我忘记了什么吗?

伊戈尔.

编辑:我发现有类似问题的人:C# SHA-1 vs. PHP SHA-1…Different Results?.解决方案是更改编码..但我无法更改服务器端的编码,因为该SQL表中的密码不是由我的应用程序创建的.
我使用JavaScript SHA1类(更确切地说是一个Google Web Toolkit类)使用客户端SHA1编码.它按预期工作和编码字符串,但显然使用ASCII字符?..

解决方法:

它与编码无关.输出将完全不同.

对于初学者,你的函数convertStringToHex()不输出前导零,即07变为7.

其余的(改变89到2030)也可能与该功能有关.尝试在passbyte = md.digest(passbyte);之后查看passbyte的值.

上一篇:是否可以使用Javascript计算文件的SHA1 ID?


下一篇:python 产生token及token验证