DotNet加密方法分析–散列加密。DotNet加密方法分析–散列加密。

by admin on 2018年10月5日

   没时间拉了,赶紧上车吧。

   没时间聊天了,赶紧上车吧。

 
 以现世社会被,信息安全于各一个人口都是最主要的,例如我们的银行账户安全、支付宝与微信账户安全、以及邮箱等等,说及消息安全,那即便得得干加密技术,至于加密的片段有关概念,在这边就背着了。

 
 于当代社会中,信息安全于各级一个总人口且是要的,例如我们的银行账户安全、支付宝和微信账户安全、以及邮箱等等,说到信息安全,那即便亟须得干加密技术,至于加密之片段连锁概念,在此就是隐瞒了。

 
 这同一涂鸦以会见要出口解.NET的加密方法,接下去将会晤独家介绍散列加密,对如加密,非对如加密等等加密方法于.NET中之应用,本文主要教学散列加密在.NET中的采用实例。

 
 这无异于破以会重要出口解.NET的加密方法,接下将会晤独家介绍散列加密,对如加密,非对如加密等等加密方法于.NET中的使,本文主要教学散列加密在.NET中之动实例。

一.DotNet散列算法概述:

 
 说及散列应该都非会见生,并且首先都见面想到MD5加密,但是对散列更加深入之问询,恐怕知道的人数尽管不见面那么基本上矣。散列算法创建了一个散列码,也号称“消息摘要”或“消息指纹”,看到“消息指纹”这个词,我首先想到的是可唯一识别一个音讯还是说好唯一的标识一个口。

一.DotNet散列算法概述:

 
 说及散列应该还不见面生,并且首先都见面想到MD5加密,但是对散列更加刻骨铭心之打听,恐怕知道之总人口虽不见面那么多了。散列算法创建了一个散列码,也叫“消息摘要”或“消息指纹”,看到“消息指纹”这个词,我第一想到的凡可唯一识别一个音讯还是说得唯一的标识一个人数。

   1.散列算法原理概述:

 散列算法的主干是一个数学函数,在简单单稳定大小的多少块被运行它们可创建一个散列码。在散列算法中需要指定一个“种子值”,该值和率先片消息数据并载入散列函数这虽很成了第一独消除列码,按照上一样步之主意,散列码依次进入下一个散列函数运算,最后收获散列码,如下图所示:

   图片 1

 
 散列码是用更调用散列函数的链创建的,散列码依赖让信息之么位的价值。散列函数是经过操作简单块固定长度的二进制数据来生成散列码,散列算法则描述类使用散列函数为信息创建散列码的长河,散列算法是利用散列函数的协议,指定类如何解释消息和如何链接之前信息快有的结果。散列码的尺寸为富有限制,散列码长度比丰富时,需要的破解时间就是会见比较丰富,这虽是暴力破解的措施,但是散列码较丰富,生成散列码的辰纵是于长,任何政策都是内需付代价的。

   1.散列算法原理概述:

 散列算法的骨干是一个数学函数,在点滴个定位大小的数码块被运行它们好创建一个散列码。在散列算法中得指定一个“种子值”,该值和率先片消息数据并载入散列函数这就是充分成了第一单败列码,按照上同样步之艺术,散列码依次进入下一个散列函数运算,最后抱散列码,如下图所示:

   图片 2

 
 散列码是运重复调用散列函数的链创建的,散列码依赖让信息之单个位的值。散列函数是由此操作简单块固定长度的二进制数据来生成散列码,散列算法则描述类以散列函数为信创建散列码的经过,散列算法是应用散列函数的商谈,指定类如何说消息以及如何链接之前信息快出的结果。散列码的长度为具限制,散列码长度比丰富时,需要的破解时间便见面较丰富,这就是是暴力破解的主意,但是散列码较丰富,生成散列码的光阴就是是比较长,任何政策都是要交给代价的。

   2.DotNet底散列算法种类:

    在.NET中,常用之散列算法种类有如下几栽:

图片 3

   
在以上列举的几栽散列算法中,MD5是.NET含有的不过抢之散列算法。如果基础算法来欠缺,越长的散列码并不一定能够提供进一步好之平安。

   2.DotNet之散列算法种类:

    在.NET中,常用的散列算法种类有如下几种:

图片 4

   
在上述列举的几种散列算法中,MD5是.NET含有的太抢之散列算法。如果基础算法有缺点,越长的散列码并不一定能够提供越来越好之安康。

二.DotNet散列算法应用解析:

 
 以上对散列算法,以及散列算法在.NET中分类做了一个简单的介绍,接下我们现实看一下再.NET中落实即几乎栽散列算法的类似。

 
 于.NET中System.Security.Cryptography命名空间下之HashAlgorithm类,表示所有加密哈希算法实现都要从中派生的基类。有如下类结构:

图片 5

 
 于.NET中产生个别种档次的落实类似,一个是因“Managed”结尾,这些近似都吃描绘副托管.NET语言,一种是以“CryptoServiceProvider”结尾,这些看似是因Windows
CryptoAPI的。接下来我们实际的垂询一下HashAlgorithm类的一些术:

二.DotNet散列算法应用解析:

 
 以上对散列算法,以及散列算法在.NET中分类做了一个略的介绍,接下去我们具体看一下再.NET中落实这几乎种植散列算法的切近。

 
 以.NET中System.Security.Cryptography命名空间下之HashAlgorithm类,表示有加密哈希算法实现全要从中派生的基类。有如下类结构:

图片 6

 
 于.NET中起个别栽类型的实现类似,一个凡是为“Managed”结尾,这些类似都受写副托管.NET语言,一栽是坐“CryptoServiceProvider”结尾,这些近似是冲Windows
CryptoAPI的。接下来我们现实的垂询一下HashAlgorithm类的一对主意:

   1.HashAlgorithm类方以及性能解析:

     (1).Hash属性:获取计算所得之哈希代码的价值。

public virtual byte[] Hash
    {
      get
      {
        if (this.m_bDisposed)
          throw new ObjectDisposedException((string) null);
        if (this.State != 0)
          throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_HashNotYetFinalized"));
        return (byte[]) this.HashValue.Clone();
      }
    }

 
该属性返回类计算机的散列码值,该属性是一个字节数组,由代码可以见到该属性是单念之,返回计算所得之哈希代码的当下价值。

     (2).Create()方法:创建哈希算法的指定实现的实例。

  public static HashAlgorithm Create(string hashName)
    {
      return (HashAlgorithm) CryptoConfig.CreateFromName(hashName);
    }

   
 由代码可知,指定哈希算法的初实例,如果hashName不是有效哈希算法,则为
null,该法应用名称创建一个HashAlgorithm对象的初实例。

     (3).ComputeHash()方法:从字节数组和数目流中创建散列码。

 public byte[] ComputeHash(byte[] buffer)
    {
      if (this.m_bDisposed)
        throw new ObjectDisposedException((string) null);
      if (buffer == null)
        throw new ArgumentNullException("buffer");
      this.HashCore(buffer, 0, buffer.Length);
      this.HashValue = this.HashFinal();
      byte[] numArray = (byte[]) this.HashValue.Clone();
      this.Initialize();
      return numArray;
    }

 
 以上是ComputeHash()方法的一个重载版本,使用字节数组来创造一个散列码,该法返回一个字节数组,该数组含有消息数据的散列码。HashCore()将写副对象的数据路由至哈希算法以计算哈希值,HashFinal()在加密流对象处理完毕最后之数后就哈希计算。

   1.HashAlgorithm类艺术及性解析:

     (1).Hash属性:获取计算所得之哈希代码的价。

public virtual byte[] Hash
    {
      get
      {
        if (this.m_bDisposed)
          throw new ObjectDisposedException((string) null);
        if (this.State != 0)
          throw new CryptographicUnexpectedOperationException(Environment.GetResourceString("Cryptography_HashNotYetFinalized"));
        return (byte[]) this.HashValue.Clone();
      }
    }

 
该属性返回类计算机的散列码值,该属性是一个字节数组,由代码可以看出该属性是一味读的,返回计算所得之哈希代码的此时此刻价。

     (2).Create()方法:创建哈希算法的指定实现的实例。

  public static HashAlgorithm Create(string hashName)
    {
      return (HashAlgorithm) CryptoConfig.CreateFromName(hashName);
    }

   
 由代码可知,指定哈希算法的新实例,如果hashName不是有效哈希算法,则也
null,该方式以名称创建一个HashAlgorithm对象的初实例。

     (3).ComputeHash()方法:从字节数组和数码流中创建散列码。

 public byte[] ComputeHash(byte[] buffer)
    {
      if (this.m_bDisposed)
        throw new ObjectDisposedException((string) null);
      if (buffer == null)
        throw new ArgumentNullException("buffer");
      this.HashCore(buffer, 0, buffer.Length);
      this.HashValue = this.HashFinal();
      byte[] numArray = (byte[]) this.HashValue.Clone();
      this.Initialize();
      return numArray;
    }

 
 以上是ComputeHash()方法的一个重载版本,使用字节数组来创造一个散列码,该措施返回一个字节数组,该数组含有消息数据的散列码。HashCore()将写副对象的数据路由至哈希算法以计算哈希值,HashFinal()在加密流对象处理完毕最后的数量后形成哈希计算。

   2.HMAC类: 表示因哈希的音讯证实代码 (HMAC) 的有所实现必须从中派生的抽象类。

     创建加密散列码(消息验证码MACs)有少栽方式:

     
 第一种:先合并类密钥和信息数据,再运普通的加密散列算法来啊该并集创建散列码。常用的凡HMAC标准。

     
 第二种植:使用对称算法来加密音数据,除了最后几乎个外,所有的加密数据位都用吃放弃。

 
 HMAC标准制订了哪些统一消息数据与密钥,但是并未点名相应下那种散列算法来创造散列码,这吗就是意味着该标准可以运用叫其他算法。

    (1).Key属性:获取或安装用于哈希算法的密钥。

 public override byte[] Key
    {
      get
      {
        return (byte[]) this.KeyValue.Clone();
      }
      set
      {
        if (this.m_hashing)
          throw new CryptographicException(Environment.GetResourceString("Cryptography_HashKeySet"));
        this.InitializeKey(value);
      }
    }

   该属性在此地进行类似更写,该属性是一个字节数组,属性可读写。

    (2).Create()方法:创建基于哈希的音讯证实代码 (HMAC) 指定实现的实例。

public static HMAC Create(string algorithmName)
    {
      return (HMAC) CryptoConfig.CreateFromName(algorithmName);
    }

   该方式指定的 HMAC
实现之初实例,该办法跟HashAlgorithm类的Create方法类似,这里就是未开深入之解析。

    (3).HashCore()方法:将写副对象的数据路由被默认 HMAC
哈希算法以计算哈希值。

  protected override void HashCore(byte[] rgb, int ib, int cb)
    {
      if (!this.m_hashing)
      {
        this.m_hash1.TransformBlock(this.m_inner, 0, this.m_inner.Length, this.m_inner, 0);
        this.m_hashing = true;
      }
      this.m_hash1.TransformBlock(rgb, ib, cb, rgb, ib);
    }

   该方式在此地让重新写,将写副对象的数据路由叫默认 HMAC
哈希算法以计算哈希值。TransformBlock()计算输入字节数组的指定区域的哈希值,将输入字节数组的指定区域复制到指定的区域,输出字节数组。

   2.HMAC类: 表示根据哈希的音证实代码 (HMAC) 的享有实现必须从中派生的抽象类。

     创建加密散列码(消息验证码MACs)有三三两两栽艺术:

     
 第一种:先合并类密钥和信数据,再使普通的加密散列算法来吗该并集创建散列码。常用之凡HMAC标准。

     
 第二种植:使用对称算法来加密音数据,除了最后几号外,所有的加密数据位都用给放弃。

 
 HMAC标准制定了怎样统一消息数据与密钥,但是没有点名相应利用那种散列算法来创造散列码,这为即意味着该标准可以为其他算法。

    (1).Key属性:获取或安装用于哈希算法的密钥。

 public override byte[] Key
    {
      get
      {
        return (byte[]) this.KeyValue.Clone();
      }
      set
      {
        if (this.m_hashing)
          throw new CryptographicException(Environment.GetResourceString("Cryptography_HashKeySet"));
        this.InitializeKey(value);
      }
    }

   该属性在这里进行类似更写,该属性是一个字节数组,属性可读写。

    (2).Create()方法:创建基于哈希的音证实代码 (HMAC) 指定实现的实例。

public static HMAC Create(string algorithmName)
    {
      return (HMAC) CryptoConfig.CreateFromName(algorithmName);
    }

   该办法指定的 HMAC
实现之初实例,该法跟HashAlgorithm类的Create方法类似,这里就无开透之解析。

    (3).HashCore()方法:将写副对象的数据路由让默认 HMAC
哈希算法以计算哈希值。

  protected override void HashCore(byte[] rgb, int ib, int cb)
    {
      if (!this.m_hashing)
      {
        this.m_hash1.TransformBlock(this.m_inner, 0, this.m_inner.Length, this.m_inner, 0);
        this.m_hashing = true;
      }
      this.m_hash1.TransformBlock(rgb, ib, cb, rgb, ib);
    }

   该方法在这里被另行写,将写副对象的数据路由让默认 HMAC
哈希算法以计算哈希值。TransformBlock()计算输入字节数组的指定区域之哈希值,将输入字节数组的指定区域复制到指定的区域,输出字节数组。

三.DotNet散列算法实现实例:

   以上介绍在.NET下之散列加密的主要类,接下看一下MD5之现实贯彻代码:

  /// <summary>
  /// 表示 MD5哈希算法的所有实现均从中继承的抽象类。
  /// </summary>
  [ComVisible(true)]
  public abstract class MD5 : HashAlgorithm
  {
    /// <summary>
    /// 初始化 MD5 的新实例。
    /// </summary>
    protected MD5()
    {
      this.HashSizeValue = 128;
    }

    /// <summary>
    /// 创建MD5 哈希算法的默认实现的实例。
    /// </summary>
    /// <returns>
    /// <see cref="T:System.Security.Cryptography.MD5"/> 哈希算法的新实例。
    /// </returns>   
    public static MD5 Create()
    {
      return MD5.Create("System.Security.Cryptography.MD5");
    }

    /// <summary>
    /// 创建MD5 哈希算法的指定实现的实例。
    /// </summary> 
    /// <returns>
    public static MD5 Create(string algName)
    {
      return (MD5) CryptoConfig.CreateFromName(algName);
    }
  }

 
 由以上的代码可以看住,在MD5像样吃,具体的实现方式还是由于HashAlgorithm类的Create方法实现,在此处就不再做牵线。

三.DotNet散列算法实现实例:

   以上介绍在.NET下之散列加密的主要类,接下去看一下MD5底切实实现代码:

  /// <summary>
  /// 表示 MD5哈希算法的所有实现均从中继承的抽象类。
  /// </summary>
  [ComVisible(true)]
  public abstract class MD5 : HashAlgorithm
  {
    /// <summary>
    /// 初始化 MD5 的新实例。
    /// </summary>
    protected MD5()
    {
      this.HashSizeValue = 128;
    }

    /// <summary>
    /// 创建MD5 哈希算法的默认实现的实例。
    /// </summary>
    /// <returns>
    /// <see cref="T:System.Security.Cryptography.MD5"/> 哈希算法的新实例。
    /// </returns>   
    public static MD5 Create()
    {
      return MD5.Create("System.Security.Cryptography.MD5");
    }

    /// <summary>
    /// 创建MD5 哈希算法的指定实现的实例。
    /// </summary> 
    /// <returns>
    public static MD5 Create(string algName)
    {
      return (MD5) CryptoConfig.CreateFromName(algName);
    }
  }

 
 由上述之代码可以看住,在MD5接近吃,具体的贯彻方式都是由HashAlgorithm类的Create方法实现,在此地虽不再做牵线。

   1.SHA1算法实例:

   public static string GetSha1(string str)
        {
            if (string.IsNullOrEmpty(str))
            {
                throw new ArgumentNullException(str);
            }
            try
            {
                //建立SHA1对象
                SHA1 sha = new SHA1CryptoServiceProvider();
                //将mystr转换成byte[] 
                var enc = new ASCIIEncoding();
                var dataToHash = enc.GetBytes(str);
                //Hash运算
                var dataHashed = sha.ComputeHash(dataToHash);
                //将运算结果转换成string
                var hash = BitConverter.ToString(dataHashed).Replace("-", "");
                return hash;
            }
            catch (ArgumentNullException ex)
            {
                throw ex;
            }
            catch (ArgumentException arex)
            {
                throw arex;
            }
            catch (ObjectDisposedException obex)
            {
                throw obex;
            }

   1.SHA1算法实例:

   public static string GetSha1(string str)
        {
            if (string.IsNullOrEmpty(str))
            {
                throw new ArgumentNullException(str);
            }
            try
            {
                //建立SHA1对象
                SHA1 sha = new SHA1CryptoServiceProvider();
                //将mystr转换成byte[] 
                var enc = new ASCIIEncoding();
                var dataToHash = enc.GetBytes(str);
                //Hash运算
                var dataHashed = sha.ComputeHash(dataToHash);
                //将运算结果转换成string
                var hash = BitConverter.ToString(dataHashed).Replace("-", "");
                return hash;
            }
            catch (ArgumentNullException ex)
            {
                throw ex;
            }
            catch (ArgumentException arex)
            {
                throw arex;
            }
            catch (ObjectDisposedException obex)
            {
                throw obex;
            }

   2.MD5加密实例:

  /// <summary>
        /// 32位大写
        /// </summary>
        /// <returns></returns>
        public static string Upper32(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile;
            return s.ToUpper();
        }

        /// <summary>
        /// 32位小写
        /// </summary>
        /// <returns></returns>
        public static string Lower32(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile;
            return s.ToLower();
        }

        /// <summary>
        /// 16位大写
        /// </summary>
        /// <returns></returns>
        public static string Upper16(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile.ToString();
            return s.ToUpper().Substring(8, 16);
        }

        /// <summary>
        /// 16位小写
        /// </summary>
        /// <returns></returns>
        public static string Lower16(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile.ToString();
            return s.ToLower().Substring(8, 16);
        }

   2.MD5加密实例:

  /// <summary>
        /// 32位大写
        /// </summary>
        /// <returns></returns>
        public static string Upper32(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile;
            return s.ToUpper();
        }

        /// <summary>
        /// 32位小写
        /// </summary>
        /// <returns></returns>
        public static string Lower32(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile;
            return s.ToLower();
        }

        /// <summary>
        /// 16位大写
        /// </summary>
        /// <returns></returns>
        public static string Upper16(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile.ToString();
            return s.ToUpper().Substring(8, 16);
        }

        /// <summary>
        /// 16位小写
        /// </summary>
        /// <returns></returns>
        public static string Lower16(string s)
        {
            var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
            if (hashPasswordForStoringInConfigFile != null)
                s = hashPasswordForStoringInConfigFile.ToString();
            return s.ToLower().Substring(8, 16);
        }

四.总结:

   
以上介绍了散列算法在.NET的动以及原理,希望得以帮忙到片丁,如果文章中出描绘的错以及不完了的地方,还为大家多多批评指正。

 
友情添加一个加密的helper方法:http://www.cnblogs.com/liqingwen/p/6155694.html

 

四.总结:

   
以上介绍了散列算法在.NET的运用和规律,希望可以扶持到有些人口,如果文章中来描绘的错误以及无成就的地方,还于大家多批评指正。

 
友情添加一个加密的helper方法:http://www.cnblogs.com/liqingwen/p/6155694.html

 

加密算法系列:

     
 DotNet加密方法分析–散列加密:http://www.cnblogs.com/pengze0902/p/6268700.html

     
 DotNet加密方法分析–对如加密:http://www.cnblogs.com/pengze0902/p/6268702.html

     
 DotNet加密方法分析–数字签名:http://www.cnblogs.com/pengze0902/p/6268709.html

     
 DotNet加密方法分析–非对如加密:http://www.cnblogs.com/pengze0902/p/6268705.html

加密算法系列:

     
 DotNet加密方法分析–散列加密:http://www.cnblogs.com/pengze0902/p/6268700.html

     
 DotNet加密方法分析–对如加密:http://www.cnblogs.com/pengze0902/p/6268702.html

     
 DotNet加密方法分析–数字签名:http://www.cnblogs.com/pengze0902/p/6268709.html

     
 DotNet加密方法分析–非对如加密:http://www.cnblogs.com/pengze0902/p/6268705.html

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图