经常出现少一位或几位的问题; 后来分析发现是字符串格式符的问题

时间:2022-06-07 05:12:09

项目开发过程中需要用到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; }