我是java安全新手,所以对你们来说听起来很愚蠢。我正在使用三重DES算法进行加密解密,因为我使用散列值作为键。我正在使用SHA-512进行散列,我听说两个相同的字符串哈希将相同,但我得到不同的输出相同的字符串。我附上sha-512的代码。如果可能,让我知道问题是什么。sha-512为相同的字符串返回不同的值
public class SHA256Algo {
public static String createHash(String text) throws UnsupportedEncodingException, NoSuchAlgorithmException
{
String encryptedText = "" ;
MessageDigest md = MessageDigest.getInstance("SHA-512");
md.update(text.getBytes("UTF-16")); // Change this to "UTF-16" if needed
byte[] digest = md.digest();
String str = digest.toString() ;
return str ;
}
public static void main(String[] args) {
try {
System.out.println(createHash("tarun")) ;
System.out.println(createHash("tarun")) ;
} catch (UnsupportedEncodingException | NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
输出:
[B @ 32d2bb53
[B @ 29086036
toString()数组没有你期望的效果。 – Arkadiy 2014-09-03 16:53:38
你可以使用第三方库吗?如果你可以使用Guava的'Hashing.sha512()。hashString(text,Charsets.UTF_16).toString()',这将会简单得多,它将完全实现你想要的。 – 2014-09-03 17:28:21