C#简单的加密类实例

 更新时间:2013年03月04日 16:20:29   作者:  
AesManaged - 高级加密标准(AES) 对称算法的管理类
复制代码 代码如下:

public static class EncryptAndDecrypt
     {
         //加密
         public static string Encrypt(string input)
         {
             // 盐值
             string saltValue = "saltValue";
             // 密码值
             string pwdValue = "pwdValue";
             byte[] data = System.Text.UTF8Encoding.UTF8.GetBytes(input);
             byte[] salt = System.Text.UTF8Encoding.UTF8.GetBytes(saltValue);
             // AesManaged - 高级加密标准(AES) 对称算法的管理类
             System.Security.Cryptography.AesManaged aes = new System.Security.Cryptography.AesManaged();
             // Rfc2898DeriveBytes - 通过使用基于 HMACSHA1 的伪随机数生成器,实现基于密码的密钥派生功能 (PBKDF2 - 一种基于密码的密钥派生函数)
             // 通过 密码 和 salt 派生密钥
             System.Security.Cryptography.Rfc2898DeriveBytes rfc = new System.Security.Cryptography.Rfc2898DeriveBytes(pwdValue, salt);
             /**/
             /*
          * AesManaged.BlockSize - 加密操作的块大小(单位:bit)
          * AesManaged.LegalBlockSizes - 对称算法支持的块大小(单位:bit)
          * AesManaged.KeySize - 对称算法的密钥大小(单位:bit)
          * AesManaged.LegalKeySizes - 对称算法支持的密钥大小(单位:bit)
          * AesManaged.Key - 对称算法的密钥
          * AesManaged.IV - 对称算法的密钥大小
          * Rfc2898DeriveBytes.GetBytes(int 需要生成的伪随机密钥字节数) - 生成密钥
          */
             aes.BlockSize = aes.LegalBlockSizes[0].MaxSize;
             aes.KeySize = aes.LegalKeySizes[0].MaxSize;
             aes.Key = rfc.GetBytes(aes.KeySize / 8);
             aes.IV = rfc.GetBytes(aes.BlockSize / 8);
             // 用当前的 Key 属性和初始化向量 IV 创建对称加密器对象
             System.Security.Cryptography.ICryptoTransform encryptTransform = aes.CreateEncryptor();
             // 加密后的输出流
             System.IO.MemoryStream encryptStream = new System.IO.MemoryStream();
             // 将加密后的目标流(encryptStream)与加密转换(encryptTransform)相连接
             System.Security.Cryptography.CryptoStream encryptor = new System.Security.Cryptography.CryptoStream
                 (encryptStream, encryptTransform, System.Security.Cryptography.CryptoStreamMode.Write);
             // 将一个字节序列写入当前 CryptoStream (完成加密的过程)
             encryptor.Write(data, 0, data.Length);
             encryptor.Close();
             // 将加密后所得到的流转换成字节数组,再用Base64编码将其转换为字符串
             string encryptedString = Convert.ToBase64String(encryptStream.ToArray());
             return encryptedString;
         }

 
         #region silverlight密码解密
         /**/
         /// <summary>
         /// 解密数据
         /// </summary>
         /// <param name="input">加密后的字符串</param>
         /// <returns>加密前的字符串</returns>
         public static string Decrypt(string input)
         {
             // 盐值(与加密时设置的值一致)
             string saltValue = "saltValue";
             // 密码值(与加密时设置的值一致)
             string pwdValue = "pwdValue";
             byte[] encryptBytes = Convert.FromBase64String(input);
             byte[] salt = Encoding.UTF8.GetBytes(saltValue);
             System.Security.Cryptography.AesManaged aes = new System.Security.Cryptography.AesManaged();
             System.Security.Cryptography.Rfc2898DeriveBytes rfc = new System.Security.Cryptography.Rfc2898DeriveBytes(pwdValue, salt);
             aes.BlockSize = aes.LegalBlockSizes[0].MaxSize;
             aes.KeySize = aes.LegalKeySizes[0].MaxSize;
             aes.Key = rfc.GetBytes(aes.KeySize / 8);
             aes.IV = rfc.GetBytes(aes.BlockSize / 8);
             // 用当前的 Key 属性和初始化向量 IV 创建对称解密器对象
             System.Security.Cryptography.ICryptoTransform decryptTransform = aes.CreateDecryptor();
             // 解密后的输出流
             MemoryStream decryptStream = new MemoryStream();
             // 将解密后的目标流(decryptStream)与解密转换(decryptTransform)相连接
             System.Security.Cryptography.CryptoStream decryptor = new System.Security.Cryptography.CryptoStream(
                 decryptStream, decryptTransform, System.Security.Cryptography.CryptoStreamMode.Write);
             // 将一个字节序列写入当前 CryptoStream (完成解密的过程)
             decryptor.Write(encryptBytes, 0, encryptBytes.Length);
             decryptor.Close();
             // 将解密后所得到的流转换为字符串
             byte[] decryptBytes = decryptStream.ToArray();
             string decryptedString = UTF8Encoding.UTF8.GetString(decryptBytes, 0, decryptBytes.Length);
             return decryptedString;
         }
         #endregion
     }

相关文章

  • WPF利用TabControl控件实现拖拽排序功能

    WPF利用TabControl控件实现拖拽排序功能

    在UI交互中,拖拽操作是一种非常简单友好的交互,这篇文章主要为大家介绍了WPF如何利用TabControl控件实现拖拽排序功能,需要的小伙伴可以参考一下
    2023-10-10
  • C#实现文本转语音功能

    C#实现文本转语音功能

    这篇文章主要为大家详细介绍了C#实现文本转语音功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Unity 按钮添加OnClick事件操作

    Unity 按钮添加OnClick事件操作

    这篇文章主要介绍了Unity 按钮添加OnClick事件操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • C# WCF简单入门图文教程(VS2010版)

    C# WCF简单入门图文教程(VS2010版)

    这篇文章主要介绍了WCF简单入门图文教程,版本是VS2010版,帮助大家轻松学习了解DataContract、ServiceContract等特性,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • C# List实现行转列的通用方案

    C# List实现行转列的通用方案

    本篇通过行转列引出了System.Linq.Dynamic,并且介绍了过滤功能,具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • C#正方形图片的绘制方法

    C#正方形图片的绘制方法

    这篇文章主要为大家详细介绍了C#正方形图片的绘制方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • C#实现简单的聊天窗体

    C#实现简单的聊天窗体

    这篇文章主要为大家详细介绍了C#实现简单的聊天窗体,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C# Socket连接请求超时机制实现代码分享

    C# Socket连接请求超时机制实现代码分享

    这篇文章主要介绍了C# Socket连接请求超时机制实现,下面提供代码分享,大家可以参考使用
    2013-12-12
  • C#简单遍历指定文件夹中所有文件的方法

    C#简单遍历指定文件夹中所有文件的方法

    这篇文章主要介绍了C#简单遍历指定文件夹中所有文件的方法,结合实例形式分析了文件夹与文件遍历的技巧,并附带说明了文件与文件夹操作的常用函数,需要的朋友可以参考下
    2016-06-06
  • Unity的IPostprocessBuild实用案例深入解析

    Unity的IPostprocessBuild实用案例深入解析

    这篇文章主要为大家介绍了Unity的IPostprocessBuild实用案例深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05

最新评论