求教一个关于.net加密算法的问题。SHA512
网上看到的跟自己写的机密方式都用过了。为什么加密出来的结果不一样?
//方法一:
public static string GETSHA512Encrypt(string strDigestStr)
{
byte[] aryEncodedData;
SHA512Managed inDigest = new SHA512Managed();
UTF8Encoding inUTF8 = new UTF8Encoding();
aryEncodedData = inUTF8.GetBytes(strDigestStr);
aryEncodedData = inDigest.ComputeHash(aryEncodedData);
String tmp = "";
for (int nLoop = 0; nLoop < aryEncodedData.Length; nLoop++)
tmp += aryEncodedData[nLoop].ToString("X2");
return tmp;
}
//方法二:
public static string SHA512Encrypt(string str)
{
System.Security.Cryptography.SHA512 s512 = new System.Security.Cryptography.SHA512Managed();
byte[] byte1;
byte1 = s512.ComputeHash(Encoding.Default.GetBytes(str));
s512.Clear();
return Convert.ToBase64String(byte1);
}
//方法三: 就在一上面 把 tmp += aryEncodedData[nLoop].ToString("X2"); 改成
tmp += aryEncodedData[nLoop].ToString("");
为什么同样加密 :JhonLocke23423432234236767785656
的出来的结果 都不一样 。 我想要的是“948914afc66ddadb2e7f70b80c9ecd07f5b4d7aa181ae50bb0ba3487027cd1b07cdd90c93c1fb0d2022033076d54019d58b45f82149c2f25fee2033312a0a228”
为什么呢 求大神解答。
SHA512
12 C# 加密算法
[解决办法]
public static string GetSHA512Password(string password)
{
byte[] bytes = Encoding.UTF7.GetBytes(password);
byte[] result;
SHA512 shaM = new SHA512Managed();
result = shaM.ComputeHash(bytes);
StringBuilder sb = new StringBuilder();
foreach (byte num in result)
{
sb.AppendFormat("{0:x2}", num);
}
return sb.ToString();
}
方法二不对吧