ASP.NET中MD5加密

(ps:感谢原作者)

 我们平常用的最多的无非就是加密用户密码,把加密好的密码存储到数据库中,进行密码比较的时候,把用户输入的密码再进行加密,然后与数据库中的密文进行比较。至于asp.net类中是如何实现加密算法的,这个我们不需要关心,会用就行了。
  下面就是Asp.net中几种加密方法。加密算法有两种,也就是上面提到的MD5SHA1,这里我举的例子是以MD5为例,SHA1大致相同,只是使用的类不一样。

  MD5 相关类:
System.Security.Cryptography.MD5

System.Security.Cryptography.MD5CryptoServiceProvider()

System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")

  SHA1相关类:
System.Security.Cryptography.SHA1

System.Security.Cryptography.SHA1CryptoServiceProvider()

System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")

 

/// <summary>
         /// 方法一:通过使用 new 运算符创建对象
         /// </summary>
         /// <param name="strSource">需要加密的明文</param>
         /// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25</returns>
         public string Get_MD5_Method1(string strSource)
         {
          //new
          System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();

          //获取密文字节数组
          byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));

          //转换成字符串,并取925
          string strResult = BitConverter.ToString(bytResult, 4, 8);
          //转换成字符串,32
          //string strResult = BitConverter.ToString(bytResult);

          //BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
          strResult = strResult.Replace("-", "");
          return strResult;
         }

 

         /// <summary>
         /// 方法二:通过调用特定加密算法的抽象类上的 Create 方法,创建实现特定加密算法的对象。
         /// </summary>
         /// <param name="strSource">需要加密的明文</param>
         /// <returns>返回32位加密结果</returns>
         public string Get_MD5_Method2(string strSource)
         {
          string strResult = "";

          //Create
          System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();

          //注意编码UTF8UTF7Unicode等的选择 
          byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));

          //字节类型的数组转换为字符串
          for (int i = 0; i < bytResult.Length; i++)
          {
           //16进制转换
           strResult = strResult + bytResult[i].ToString("X");
          }
          return strResult;
         }

 

         /// <summary>
         /// 方法三:直接使用HashPasswordForStoringInConfigFile生成
         /// </summary>
         /// <param name="strSource">需要加密的明文</param>
         /// <returns>返回32位加密结果</returns>
         public string Get_MD5_Method3(string strSource)
         {
          return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");
         }

 

     注意:方法二不稳定,有时返回的是30位(如加密123时),尽量少用方法二!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值