zoukankan      html  css  js  c++  java
  • 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();
      }

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

  • 相关阅读:
    【数学建模】—优秀论文(一)
    【数学建模】—论文排版
    【Linux学习】—第8章linux编程
    【Linux学习】—文件权限和目录配置
    【ESP8266学习】(一)
    【OpenCV】——b站达尔闻
    【Linux学习】——Shell编程基础
    【数学建模】——模拟退火算法(SAA)
    react 开发中火狐,Safari浏览器嵌套iframe显示空白
    element ui dataPicker 日期范围限制
  • 原文地址:https://www.cnblogs.com/jiangyu/p/5086.html
Copyright © 2011-2022 走看看