using System;

namespace Encrypt
{
public class AESHelper
{
/// <summary>
/// 默认密钥-密钥的长度必须是32
/// </summary>
private const string PublicKey = "1234567890123456"; /// <summary>
/// 默认向量
/// </summary>
private const string Iv = "abcdefghijklmnop";
/// <summary>
/// AES加密
/// </summary>
/// <param name="str">需要加密字符串</param>
/// <returns>加密后字符串</returns>
public static String Encrypt(string str)
{
return Encrypt(str, PublicKey);
} /// <summary>
/// AES解密
/// </summary>
/// <param name="str">需要解密字符串</param>
/// <returns>解密后字符串</returns>
public static String Decrypt(string str)
{
return Decrypt(str, PublicKey);
}
/// <summary>
/// AES加密
/// </summary>
/// <param name="str">需要加密的字符串</param>
/// <param name="key">32位密钥</param>
/// <returns>加密后的字符串</returns>
public static string Encrypt(string str, string key)
{
Byte[] keyArray = System.Text.Encoding.UTF8.GetBytes(key);
Byte[] toEncryptArray = System.Text.Encoding.UTF8.GetBytes(str);
var rijndael = new System.Security.Cryptography.RijndaelManaged();
rijndael.Key = keyArray;
rijndael.Mode = System.Security.Cryptography.CipherMode.ECB;
rijndael.Padding = System.Security.Cryptography.PaddingMode.PKCS7;
rijndael.IV = System.Text.Encoding.UTF8.GetBytes(Iv);
System.Security.Cryptography.ICryptoTransform cTransform = rijndael.CreateEncryptor();
Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
return Convert.ToBase64String(resultArray, 0, resultArray.Length);
}
/// <summary>
/// AES解密
/// </summary>
/// <param name="str">需要解密的字符串</param>
/// <param name="key">32位密钥</param>
/// <returns>解密后的字符串</returns>
public static string Decrypt(string str, string key)
{
Byte[] keyArray = System.Text.Encoding.UTF8.GetBytes(key);
Byte[] toEncryptArray = Convert.FromBase64String(str);
var rijndael = new System.Security.Cryptography.RijndaelManaged();
rijndael.Key = keyArray;
rijndael.Mode = System.Security.Cryptography.CipherMode.ECB;
rijndael.Padding = System.Security.Cryptography.PaddingMode.PKCS7;
rijndael.IV = System.Text.Encoding.UTF8.GetBytes(Iv);
System.Security.Cryptography.ICryptoTransform cTransform = rijndael.CreateDecryptor();
Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
return System.Text.Encoding.UTF8.GetString(resultArray);
}
}
}

最新文章

  1. bootstrap-datetimepicker 进一步跟进~~~开始时间和结束时间的样式显示
  2. VirtualPathProvider的使用
  3. Labview调用Python脚本
  4. [hihoCoder1329] 带Split和Merge的Treap
  5. native
  6. 【转】用串口登录Beaglebone Black、用usb共享电脑网络、内核模块的本地编译
  7. 加班计时App
  8. java中权限修饰符protected的使用注意事项
  9. 敏捷冲刺每日报告五(Java-Team)
  10. MESSAGE_TYPE_X in Badi:MB_DOCUMENT_UPDATE_BEFORE
  11. 编程实现类似Linux下cp功能
  12. vue 学习笔记1
  13. 04:第一个OC类
  14. OpenCV学习C++接口 Mat像素遍历详解
  15. Kafka+Storm+HDFS 整合示例
  16. tf.placeholder使用说明
  17. 【BZOJ3992】【SDOI2015】序列统计 EGF+多项式快速幂+循环卷积
  18. 怎么样退出vi/vim编辑器
  19. poj_3662 最小化第k大的值
  20. JS-元素大小深入学习-offset、client、scroll等学习研究笔记

热门文章

  1. 为了考PMP,我做了一个刷题小程序
  2. Storm 学习之路(五)—— Storm编程模型详解
  3. 第一个SpringBoot
  4. python基本数据类型之数字类型和其相关运算
  5. 嵌入式物联网32 ARM linux 等创客学院学习视频共享给大家
  6. 阿里巴巴 -- MySQL DBA 面试题
  7. Java 中的字符串(String)与C# 中字符串(string)的异同
  8. tomcat 启动窗口 名称 中文乱码
  9. 法国神器&quot;mimikatz&quot;简化版,一键导出结果
  10. MyBatis从入门到精通(十):使用association标签实现嵌套查询