C# MD5 32位加密 UTF-8编码
2015-07-23 17:35
281 查看
项目开发过程中需要用到MD5加密,最开始的使用使用加密方法:
public static string GetMD5(string str)
{
byte[] b = System.Text.Encoding.Default.GetBytes(str);
b = new System.Security.Cryptography.MD5CryptoServiceProvider().ComputeHash(b);
string ret = "";
for (int i = 0; i < b.Length; i++)
{
ret += b[i].ToString("x").PadLeft(2, '0');
}
return ret;
}
在一开始的测试过程中没有出现问题,后来传入的参数包含中文后,就出现问题了,
经过排查返现Encoding.Default使用的是默认的编码:gb2312
所以改变加密方式:
public static string UserMd5(string str)
{
string cl = str;
string pwd = "";
MD5 md5 = MD5.Create();//实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("x");
}
return pwd;
}
但是在和对方测试过程中,发现我这边的MD5加密编码,经常出现少一位或几位的问题;
后来分析发现是 字符串格式符的问题, X 表示大写, x 表示小写, X2和x2表示不省略首位为0的十六进制数字;
比如:ox0A, 使用X== 0xA, 使用X2==0x0A
则改变方法最后的输出格式:
public static string UserMd5(string str)
{
string cl = str;
string pwd = "";
MD5 md5 = MD5.Create();//实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("x2");
}
return pwd;
}
--------------------------------------------------------------------------------------------------------------------------
public static string GetMD5(string str)
{
byte[] b = System.Text.Encoding.Default.GetBytes(str);
b = new System.Security.Cryptography.MD5CryptoServiceProvider().ComputeHash(b);
string ret = "";
for (int i = 0; i < b.Length; i++)
{
ret += b[i].ToString("x").PadLeft(2, '0');
}
return ret;
}
在一开始的测试过程中没有出现问题,后来传入的参数包含中文后,就出现问题了,
经过排查返现Encoding.Default使用的是默认的编码:gb2312
所以改变加密方式:
public static string UserMd5(string str)
{
string cl = str;
string pwd = "";
MD5 md5 = MD5.Create();//实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("x");
}
return pwd;
}
但是在和对方测试过程中,发现我这边的MD5加密编码,经常出现少一位或几位的问题;
后来分析发现是 字符串格式符的问题, X 表示大写, x 表示小写, X2和x2表示不省略首位为0的十六进制数字;
比如:ox0A, 使用X== 0xA, 使用X2==0x0A
则改变方法最后的输出格式:
public static string UserMd5(string str)
{
string cl = str;
string pwd = "";
MD5 md5 = MD5.Create();//实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("x2");
}
return pwd;
}
--------------------------------------------------------------------------------------------------------------------------
相关文章推荐
- c#调用硬件提供的二次开发函数方法
- csharp: 用Enterprise Library对象实体绑定数据
- C# + Socket断线重连
- C#高级编程五十一天----链表
- Visual Studio 2015速递(1)——C#6.0新特性怎么用
- C#中流,字节,字符,字符串
- C# 性能优化——三种字符串拼接效率
- C#怎么判断一个Socket是否连接
- 控件大小随窗口大小改变
- C#中ArrayList类的使用
- C#中ArrayList类的使用
- C#对Windows文件的操作
- c#中文字符串与byte数组互相转化
- C#使用SOAP获取webservice实例解析
- c#延迟加载
- c#的中英文混合字符串截取 public static string SubString(string inputString, int byteLength)
- c#的中英文混合字符串截取指定长度,startidx从0开始
- 浅谈C#中Control的Invoke与BeginInvoke在主副线程中的执行顺序和区别
- C# 加密解密(DES,3DES,MD5,Base64) 类
- C#文件的处理