如果我从Mac调用命令
echo hello | shasum -a 256
或者来自ubuntu
echo hello | sha256sum
然后我得到以下结果
5891b5b522d5df086d0ff0b110fbd9d21bb4fc7163af34d08286a2e846f6be03 -
我注意到结尾有破折号。
但是当我使用Pythonhashlib
或Javajava.security.MessageDigest
时,它们给出的结果如下:
2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824
那么,有谁能指出我哪里弄错了吗?
谢谢。
Python:
>>> import hashlib
>>> hashlib.sha256("hello").hexdigest()
爪哇语:
MessageDigest md = MessageDigest.getInstance("SHA-256");
String text = "hello";
md.update(text.getBytes("UTF-8"));
byte[] digest = md.digest();
StringBuffer sb = new StringBuffer();
for (int i = 0; i < digest.length; i++) {
sb.append(String.format("%02x", digest[i] & 0xFF))
}
System.out.println(sb.toString());
echo
命令正在向字符串添加尾随换行符。尝试:sha256sum
和相关命令正在输出中添加破折号:-
。这些命令用于显示*文件的哈希值。单破折号表示输入来自标准inpuIt流(即没有文件名)。不幸的是,我看不到抑制输出的选项,所以您必须自己删除它才能得到实际的散列值。因此哈希实用程序不仅返回哈希值。SHA-256哈希值仅由32个字节组成。由于人类无法读取二进制文件,二进制文件使用十六进制显示,但实际值仍应视为字节。十六进制字符只是这些字节的表示。
哈希函数的输入也由位或字节组成。这意味着编码文本的任何差异都意味着散列值将不同。当涉及到空白和行尾编码时,这尤其棘手。不过,在“hello”的情况下,最好使用
echo
命令的-n
命令行选项来抑制它,而不是添加后面的换行符。因此,请尝试以下操作:
或者,使用OpenSSL(它有类似的问题):
这还将删除后面的换行符,以便您可以进行十六进制比较。
对于Java,还应该确保文本编码与系统默认编码匹配,否则可能会遇到麻烦。所以你应该改变:
到
以获取平台字符编码。如果不这样做,则如果要比较的字符串的平台编码与UTF-8不兼容,则比较将失败。
在没有行尾的Python中,要完成这个答案:
请注意,十六进制本身也可以以不同的方式显示;您将确保不存在空白,并且比较不区分大小写,或者字节的表示始终使用相同的大小写。
相关问题 更多 >
编程相关推荐