MD5之C#密码加密-备忘录

mac2022-06-30  31

MD5算法说明:  加密算法都是对字节数组或流进行加密的。MD5的算法则是对原始的字节数组随机(有算法的随机)抽取几个字节,经过运算后返回新的字节(加密以后的字节)。它不 仅可以对字符串进行加密,也可以对文件进行加密。加密以后的数据已经不同于原始的数据,随机抽取字节导致不可逆。内部算法又保证对相同字符串加密的结果相同。MD5值是有限的,但是源数据是无限的,所以存在不同的内容加密后得到相同MD5值的情况(这里也可以看出它的不可逆性)。但是这个概率非常低,所以,我们在给用户密码加密时,一般不考虑这种情况。

一、对字符串加密

        /// 加密字符串        /// </summary>        /// <param name="str">要加密的字符串</param>        /// <returns>加密后的字符串(MD5值)</returns>        private string MD5EncryptionString(string str)        {            MD5CryptoServiceProvider md5Provider = new MD5CryptoServiceProvider();            byte[] temp=System.Text.Encoding.ASCII.GetBytes(str);            byte[] md5Byte=md5Provider.ComputeHash(temp);            //直接将字节数据转换成字符串发现发乱码,是因为这个字节数组不一定就是某个字符或字符串的字节数组。            //string md5Value = System.Text.Encoding.ASCII.GetString(md5Byte);            string md5Value = string.Empty;            //整个字节数组转不成功,我们就转换它的每一个字节,将每一个字节转换成十六进制数            //1.“x”表示十六进制小写            //2.“X”表示十六进制大写            foreach (var item in md5Byte)            {                md5Value += item.ToString("x2");            }            return md5Value;        }

 

二、对文件加密

         /// <summary>        /// 加密文件        /// </summary>        /// <param name="filePath">文件路径</param>        /// <returns>加密后的字符串</returns>        private string MD5EncryptionFile(string filePath)        {            MD5CryptoServiceProvider provider = new MD5CryptoServiceProvider();            byte[] md5Byte = null;            string md5Value = string.Empty;            using(FileStream fs=new FileStream (filePath,FileMode.Open))            {                md5Byte = provider.ComputeHash(fs);            }            foreach (var item in md5Byte)            {                md5Value += item.ToString("x2");            }            return md5Value;        }

转载于:https://www.cnblogs.com/XChWaad/archive/2012/08/06/2625025.html

相关资源:ASP.NET开发实战1200例(第2卷).(清华出版.房大伟.吕双).part1
最新回复(0)