C# AES 加解密处理
引言
这是一个有关AES加解密的方法类
一、设置AES加解密密钥:下面列出自己分配的三类密钥
private const string UserKey = "roshan-2015-user"; //加密用户名和密码
private static readonly byte[] UserIv = { , , 0xF, , , 0xC, , 0xB, , 0x5B, 0xD, 0x17, , 0xA, , }; private const string ServerAuthTokenKey = "roshan2015server"; //加密服务端AuthToken
private static readonly byte[] ServerAuthTokenIv = { 0xC, , 0xB, , 0x5B, 0xD, , , 0xF, , , 0x17, , 0xA, , }; private const string ClientAuthTokenKey = "roshan2015client";//加密客户端AuthToken
private static readonly byte[] ClientAuthTokenIv = { 0x38, 0x31, 0x37, 0x34, 0x36, 0x33, 0x35, 0x33, 0x32, 0x31, 0x34, 0x38, 0x37, 0x36, 0x35, 0x32 };
密钥设置
二、填充方法:这里个人采用默认的填充方法
Mode:CBC
Padding:PKCS7
三、配置加解密方法
/// <summary>
/// 加密
/// </summary>
/// <param name="toEncrypt">明文</param>
/// <param name="key">秘钥</param>
/// <param name="ivBytes">向量</param>
/// <returns>密文</returns>
public static string AESEncrypt(string toEncrypt, string key, byte[] ivBytes)
{
byte[] toEncryptBytes = System.Text.Encoding.UTF8.GetBytes(toEncrypt);
var rijndael = new RijndaelManaged();
rijndael.Key = System.Text.Encoding.UTF8.GetBytes(key);
rijndael.IV = ivBytes;
ICryptoTransform cryptoTransform = rijndael.CreateDecryptor();
byte[] resultBytes = cryptoTransform.TransformFinalBlock(toEncryptBytes, , toEncryptBytes.Length);
return Convert.ToBase64String(resultBytes);
}
加密方法
/// <summary>
/// 解密
/// </summary>
/// <param name="toDecrypt">密文</param>
/// <param name="key">秘钥</param>
/// <param name="ivBytes">向量</param>
/// <returns>明文</returns>
private static string AESDecrypt(string toDecrypt, string key, byte[] ivBytes)
{
byte[] toDecryptBytes = Convert.FromBase64String(toDecrypt);
var rijndael = new RijndaelManaged();
rijndael.Key = System.Text.Encoding.UTF8.GetBytes(key);
rijndael.IV = ivBytes;
ICryptoTransform cryptoTransform = rijndael.CreateDecryptor();
byte[] resultArray = cryptoTransform.TransformFinalBlock(toDecryptBytes, , toDecryptBytes.Length);
return System.Text.Encoding.UTF8.GetString(resultArray);
}
解密方法
C# AES 加解密处理的更多相关文章
- DES,AeS加解密,MD5,SHA加密
1.DES一共就有4个参数参与运作:明文.密文.密钥.向量.其中这4者的关系可以理解为: 密文=明文+密钥+向量: 明文=密文-密钥-向量: 为什么要向量这个参数呢?因为如果有一篇文章,有几个词重复, ...
- c# Aes加解密和对象序列化
aes加解密 public class AesCryptto { private string key = "hjyf57468jhmuist"; private string i ...
- Java、C#双语版配套AES加解密示例
这年头找个正经能用的东西那是真难,网上一搜索一大堆,正经能用的没几个,得,最后还是得靠自己,正巧遇上需要AES加解密的地方了,而且还是Java和C#间的相互加解密操作,这里做个备忘 这里采用的加解 ...
- AES加解密算法Qt实现
[声明] (1) 本文源码 在一位未署名网友源码基础上,利用Qt编程,实现了AES加解密算法,并添加了文件加解密功能.在此表示感谢!该源码仅供学习交流,请勿用于商业目的. (2) 图片及描述 除图1外 ...
- aes加解密 Illegal key size
做aes加密时,发生一个奇怪的错误,在本地环境是好的,发布到测试环境就出问题, java.security.InvalidKeyException: Illegal key size 想到本地环境之前 ...
- C# RSA加解密与验签,AES加解密,以及与JAVA平台的密文加解密
前言: RSA算法是利用公钥与密钥对数据进行加密验证的一种算法.一般是拿私钥对数据进行签名,公钥发给友商,将数据及签名一同发给友商,友商利用公钥对签名进行验证.也可以使用公钥对数据加密,然后用私钥对数 ...
- Aes加解密,php
Aes类库 <?php namespace Aes; class Aes { /** * var string $method 加解密方法,可通过openssl_get_cipher_metho ...
- cryptoJS AES 加解密简单使用
简单记录一下,前端利用 cryptoJS 如何加解密的.主要是关于 AES 加解密. 需求描述:需要对 url 中的参数进行 AES 解密,然后再把该参数进行 MD5 加密通过接口传递. AES AE ...
- AES加解密程序的实现
AES加解密程序的实现正常情况,用户不能访问sys.dbms_crypto,需要DBA授权:grant execute on dbms_crypto to crm;建立加解密的PKG_AES包:CRE ...
- 收银台数据库存储AES加解密
高级加密标准(AES,Advanced Encryption Standard)为最常见的对称加密算法加密和解密用到的密钥是相同的,这种加密方式加密速度非常快,适合经常发送数据的场合.缺点是密钥的传输 ...
随机推荐
- swift使用查阅资料备份4
Swift - RxSwift的使用详解6(观察者2: 自定义可绑定属性) http://www.hangge.com/blog/cache/detail_1946.html extension UI ...
- 聊聊 TCP 中的 KeepAlive 机制
KeepAlive并不是TCP协议规范的一部分,但在几乎所有的TCP/IP协议栈(不管是Linux还是Windows)中,都实现了KeepAlive功能 RFC1122#TCP Keep-Alives ...
- 进程线程之pid,tid
Linux中,每个进程有一个pid,类型pid_t,由getpid()取得.Linux下的POSIX线程也有一个id,类型pthread_t,由pthread_self()取得,该id由线程维护,其i ...
- python安装Redis数据库
where pip cd 切换这个目录 pip install redis import redis r = redis.Redis(host='127.0.0.1', port=6379) user ...
- IOS - autoresizingMask
提醒:当frame设定死,慎用autoresizingMask:否则该frame变形的难以想象.
- hp soap扩展最全说明,附天气预报调用的例子
自从php5开始,我们可以不用通过php nusoap来创建php soap web service 和调用 soap了,php5内置了 soap扩展.只需要在php.ini中开启soap的exten ...
- 基于bootstrap的分页组件-Bootstrap Paginator
效果
- Unity的Json解析<一>--读取Json文件
本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/details/50373558 作者:car ...
- C# 实现窗口程序winform像QQ一样靠近桌面边缘自动隐藏窗口
实现原理: 实现这个功能的原理步骤如下: 1.判断窗体程序是否靠近桌面边缘: 2.获取桌面屏幕大小与窗体程序大小: 3.把窗体程序显示在桌面以外隐藏起来,预留部分窗体方便用户拉出程序: 4.判断鼠标是 ...
- CF735E Ostap and Tree
比较毒瘤的树形DP,子状态难想.这是主要是搬运一篇题解. 用\(f[i][j]\)表示\(i\)的子树中离\(i\)最近黑点的距离为\(j\),且距离超过\(j\)的点都被满足的方案数.转移时新建一个 ...