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

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

  • 相关阅读:
    思维科学的层次和学科构成
    知识管理--要对自己的知识做顶层的梳理和管理
    深入分析泛型编程--编译器使用模版生成代码
    算法与上下文
    深入理解递归算法
    什么是递归:递 与 归
    分治与”分析与综合”
    分治的逻辑学描述
    分治与递归
    generator的本质是将异步的管理剥离
  • 原文地址:https://www.cnblogs.com/jiangyu/p/5086.html
Copyright © 2011-2022 走看看