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();
      }

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

  • 相关阅读:
    ipython是python的交互式shell工具
    [pip]安装和管理python第三方包
    django 文件上传 研究
    matplotlib01
    mysql数据导出为excel文件
    怎么查看mysql的数据库编码格式
    动态图片、图表
    django 生成复杂的 PDF 文件(数据较多时)
    链接sql数据库并输出csv文件
    django生成文件txt、pdf(在生成 PDF 文件之前,需要安装 ReportLab 库)
  • 原文地址:https://www.cnblogs.com/jiangyu/p/5086.html
Copyright © 2011-2022 走看看