C#使用MD5加密

关于MD5的简介:https://baike.baidu.com/item/MD5/212708?fr=aladdin

百度百科上有详细记得介绍,这里就不做过多的介绍了

            //MD5类是抽象类
            MD5 md5 =MD5.Create();
            //需要将字符串转成字节数组
            byte[] buffer = Encoding.Default.GetBytes("123");
            //加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
            byte[] md5buffer = md5.ComputeHash(buffer);
            string str = null;
            // 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
            foreach (byte b in md5buffer)
            {
                //得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符 
                //但是在和对方测试过程中,发现我这边的MD5加密编码,经常出现少一位或几位的问题;
                //后来分析发现是 字符串格式符的问题, X 表示大写, x 表示小写, 
                //X2和x2表示不省略首位为0的十六进制数字;
                str += b.ToString("x2");
            }
            Console.WriteLine(str);//202cb962ac59075b964b07152d234b70
            Console.ReadKey();
        }

这个就是主要的加密过程,由于加密过程是不可逆的,所以当使用验证的时候,需要将输入的时候进行加密然后去验证,

posted @ 2020-05-10 19:22  小白打卡  阅读(14286)  评论(1编辑  收藏  举报