using System.Security.Cryptography;
/// <summary>
/// // 计算字符串的MD5码
/// </summary>
/// <param name="str">需要加密的字符串(此字符串是通过utf-8编码的)</param>
/// <returns>返回值</returns>
public static string MD5Digest(string str)
{
string pwd = "";
if (str != "")
{
MD5 inst = MD5.Create();
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = inst.ComputeHash(System.Text.Encoding.UTF8.GetBytes(str));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X2)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("X2");
}
}
return pwd;
}
/// <summary>
/// //计算字节数组的MD5码
/// </summary>
/// <param name="data">要加密的字节数组</param>
/// <returns>返回值</returns>
public static string MD5Digest(byte[] data)
{
string pwd = "";
if (data.Length > 0)
{
MD5 inst = MD5.Create();
byte[] s = inst.ComputeHash(data);
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X2)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("X2");
}
}
return pwd;
}
/// <summary>
/// // 计算字节数组指定部分的MD5码
/// </summary>
/// <param name="data">要加密的字节数组</param>
/// <param name="offset">偏移量(从此位置开始加密)</param>
/// <param name="len">加密长度(几个字节)</param>
/// <returns>返回值</returns>
public static string MD5Digest(byte[] data, int offset, int len)
{
string pwd = "";
if (data.Length > 0)
{
MD5 inst = MD5.Create();
byte[] s = inst.ComputeHash(data,offset,len);
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X2)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("X2");
}
}
return pwd;
}
}
MD5 加密
最新推荐文章于 2022-12-28 13:50:25 发布