/// <summary>
/// MD5 32位加密
/// </summary>
/// <param name="strUserPassWord">待加密的密码字符串</param>
/// <param name="bIsUpper">是否返回大写加密后字符串</param>
/// <returns>返回32位加密后的密码字符串</returns>
public static string UserPassWord_Md5(string strUserPassWord, bool bIsUpper)
{
//加密后字符串
string strPassWord = "";
MD5 md5 = MD5.Create();//实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] byteStr = md5.ComputeHash(Encoding.UTF8.GetBytes(strUserPassWord));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < byteStr.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
if (bIsUpper)
strPassWord = strPassWord + byteStr[i].ToString("X");
else
strPassWord = strPassWord + byteStr[i].ToString();
}
return strPassWord;
}
/// MD5 32位加密
/// </summary>
/// <param name="strUserPassWord">待加密的密码字符串</param>
/// <param name="bIsUpper">是否返回大写加密后字符串</param>
/// <returns>返回32位加密后的密码字符串</returns>
public static string UserPassWord_Md5(string strUserPassWord, bool bIsUpper)
{
//加密后字符串
string strPassWord = "";
MD5 md5 = MD5.Create();//实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] byteStr = md5.ComputeHash(Encoding.UTF8.GetBytes(strUserPassWord));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < byteStr.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
if (bIsUpper)
strPassWord = strPassWord + byteStr[i].ToString("X");
else
strPassWord = strPassWord + byteStr[i].ToString();
}
return strPassWord;
}