C#加密解密(AES)
2024-09-01 00:05:03
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);
}
}
}
最新文章
- bootstrap-datetimepicker 进一步跟进~~~开始时间和结束时间的样式显示
- VirtualPathProvider的使用
- Labview调用Python脚本
- [hihoCoder1329] 带Split和Merge的Treap
- native
- 【转】用串口登录Beaglebone Black、用usb共享电脑网络、内核模块的本地编译
- 加班计时App
- java中权限修饰符protected的使用注意事项
- 敏捷冲刺每日报告五(Java-Team)
- MESSAGE_TYPE_X in Badi:MB_DOCUMENT_UPDATE_BEFORE
- 编程实现类似Linux下cp功能
- vue 学习笔记1
- 04:第一个OC类
- OpenCV学习C++接口 Mat像素遍历详解
- Kafka+Storm+HDFS 整合示例
- tf.placeholder使用说明
- 【BZOJ3992】【SDOI2015】序列统计 EGF+多项式快速幂+循环卷积
- 怎么样退出vi/vim编辑器
- poj_3662 最小化第k大的值
- JS-元素大小深入学习-offset、client、scroll等学习研究笔记
热门文章
- 为了考PMP,我做了一个刷题小程序
- Storm 学习之路(五)—— Storm编程模型详解
- 第一个SpringBoot
- python基本数据类型之数字类型和其相关运算
- 嵌入式物联网32 ARM linux 等创客学院学习视频共享给大家
- 阿里巴巴 -- MySQL DBA 面试题
- Java 中的字符串(String)与C# 中字符串(string)的异同
- tomcat 启动窗口 名称 中文乱码
- 法国神器";mimikatz";简化版,一键导出结果
- MyBatis从入门到精通(十):使用association标签实现嵌套查询