• System.Web.Security下提供了非常简单的MD5加密算法,但处在非Web层的项目要怎么使用MD5加密呢?


    我起初没有太在意,在web层用了这样的md5加密方法。
      public static string MD5(string str)
      {
       return FormsAuthentication.HashPasswordForStoringInConfigFile(str,"md5");
      }

    在非web层用了这样的md5加密方法。
      public static string MD5(string str)
      {
       byte[] bValue;
       byte[] bHash;
       string result=null;
       MD5CryptoServiceProvider MD5=new MD5CryptoServiceProvider();

       bValue=System.Text.Encoding.UTF8.GetBytes(str);

       bHash = MD5.ComputeHash(bValue);

       MD5.Clear();

       return Convert.ToBase64String(bHash);
      }

    但实际上两种方法输出的结果并不一样,我在msdn上查了一下,并没有发现我什么地方有错。
    后果我对这种方法做了一些改进。

      public static string MD5(string str)
      {
       byte[] bValue;
       byte[] bHash;
       string result=null;
       MD5CryptoServiceProvider MD5=new MD5CryptoServiceProvider();

       bValue=System.Text.Encoding.UTF8.GetBytes(str);

       bHash = MD5.ComputeHash(bValue);

       MD5.Clear();

       for (int i=0; i<bHash.Length; i++)
       {
        if(bHash[i].ToString("x").Length==1)  
        {
         //如果返回来是07这样的值,0会被省掉,所以强制加了一个0
         result += "0"+bHash[i].ToString("x");
        }
        else
        {
         result += bHash[i].ToString("x");
        }
        
       }
       return result.ToUpper();
      }

    成功了:)
    但不知道是我自作聪明呢,还是有编码的问题或是别的什么,但总算结果一样拉

  • 相关阅读:
    运算符的优先级
    % 取余运算 取模运算
    Java运算符,关系运算符
    自增自减 a++,++a,a--,--a
    Java运算符,算术运算符
    启用div作为编辑器 添加contentEditalbe = “true”,如何让在Html中特殊字符不被转义
    一个合格前端必看的书籍
    JQuery中eq()和get()的区别
    div,contenteditable编辑器之ctrl+enter换行,enter发送
    Angularjs 源码
  • 原文地址:https://www.cnblogs.com/jiangyu/p/5086.html
Copyright © 2020-2023  润新知