不同语言的md5加密同一字符串,结果是不一样的吗?

我用C# 和 as3 对同一字符串加密,可结果不同。
正常吗?

还是我哪错了。

首先不同的语言的md5加密方式肯定是一样的

使用C#的MD5加密时要注意几点:
1.密码是中文的:md5Hasher.ComputeHash(Encoding.GetEncoding("gb2312").GetBytes("中文"));
英文的要注意转换字符集(对于常用的MS有点反了,反正针对密码所用的字符集就行了)
2.如果要匹配数据库的密码,sql的md5加密是补足位数的,而网上的算法没有做这件事,所以经常会出现少几位的情况,而且少的几位肯定是“0”所以要注意补0,也就是ToString("X2")

贴一段代码:
static void Main(string[] args)
{
MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider();
byte[] hashedDataBytes;
hashedDataBytes = md5Hasher.ComputeHash(Encoding.GetEncoding("gb2312").GetBytes("中文"));
StringBuilder tmp = new StringBuilder();
foreach (byte i in hashedDataBytes)
{
tmp.Append(i.ToString("x2")); //就是这里的处理
}
Console.WriteLine(tmp.ToString());
Console.Read();
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2010-10-21
呵呵,MD5密分两种,一种为16位的,一种为32位的,也就是说加密后的密文长度不一样,如果是16位的加密后一个字符的长度变为16个,所有语言加密后应该是一样的,如果不是那就不叫md5加密了 ,语言不同,最多是加密的过程可能有不同,但最后结果是一样的,而且是肯定是一样,这点是可以肯定的。要不要然那就不叫md5加密了,呵呵!
相似回答