[TestClass]
public class UnitTest1
{
[TestMethod]
public void TestMethod1()
{
var key = "cheayeon";
var iv = "encoding";
var text = "sb sb ha ha ha";
//对text,key iv 进行base64加密
var enKey = Convert.ToBase64String(Encoding.UTF8.GetBytes(key));
var enIv = Convert.ToBase64String(Encoding.UTF8.GetBytes(iv));
var enText = Convert.ToBase64String(Encoding.UTF8.GetBytes(text));
//加密
var encryp = AesEncryp(enText, enKey,enIv);
//解密
var decryp = AesDecryp(encryp, enKey, enIv); }
/// <summary>
/// 加密密text
/// 王剑锋 2018年7月7日09:58:34
/// </summary>
/// <param name="text">明文</param>
/// <param name="key">秘钥,Base64串</param>
/// <param name="iv">向量,Base64串</param>
/// <returns></returns>
public string AesEncryp(string text,string key,string iv)
{
var aes = Aes.Create();
//AES-128-CBC PKCS#7
aes.Mode = CipherMode.CBC;
aes.Padding = PaddingMode.PKCS7;
aes.KeySize = 128;
aes.BlockSize = 128;
//Base64解密text,KEY,IV,不够16位填充0
aes.Key = Padding16(Convert.FromBase64String(key),0);
aes.IV = Padding16(Convert.FromBase64String(iv),0);
//获取该算法规则下的加密器
var encryp = aes.CreateEncryptor();
//加密之前加一个Base64解密 ,要加密的数据
var dataBytes = Convert.FromBase64String(text);
//获取AES-128-CBC PKCS#7 密文
var enData = encryp.TransformFinalBlock(dataBytes,0, dataBytes.Length);
return Convert.ToBase64String(enData);
}
/// <summary>
/// 解密text
/// 王剑锋 2018年7月7日09:58:16
/// </summary>
/// <param name="text">密文</param>
/// <param name="key">秘钥,Base64串</param>
/// <param name="iv">向量,Base64串</param>
/// <returns></returns>
public string AesDecryp(string text, string key, string iv)
{
var aes = Aes.Create();
//AES-128-CBC PKCS#7
aes.Mode = CipherMode.CBC;
aes.Padding = PaddingMode.PKCS7;
aes.KeySize = 128;
aes.BlockSize = 128;
//Base64解密text,KEY,IV
aes.Key = Padding16(Convert.FromBase64String(key),0);
aes.IV = Padding16(Convert.FromBase64String(iv),0);
//获取该算法规则下的解密器
var encryp = aes.CreateDecryptor();
//加密之前加一个Base64解密 ,要加密的数据
var dataBytes = Convert.FromBase64String(text);
//获取AES-128-CBC PKCS#7 明文
var enData = encryp.TransformFinalBlock(dataBytes, 0, dataBytes.Length);
return Encoding.UTF8.GetString(enData);
}
/// <summary>
/// 不够16位的整数倍,已指定字符填充
/// </summary>
/// <param name="array"></param>
/// <param name="padding"></param>
/// <returns></returns>
public byte[] Padding16(byte [] array,byte padding)
{
int group = (array.Length + 15) / 16;
var newArray = new byte[group*16];
for (int i = 0; i < newArray.Length; i++)
{
newArray[i] = (i < array.Length ? array[i] : padding);
}
return newArray;
}

  

微信AES-128-CBC加密解密的更多相关文章

  1. 微信小程序aes前后端加密解密交互

    aes前后端加密解密交互 小程序端 1. 首先引入aes.js /** * [description] CryptoJS v3.1.2 * [description] zhuangzhudada so ...

  2. golang AES/ECB/PKCS5 加密解密 url-safe-base64

    因为项目的需要用到golang的一种特殊的加密解密算法AES/ECB/PKCS5,但是算法并没有包含在标准库中,经过多次失败的尝试,终于解码成功,特此分享: /* 描述 : golang AES/EC ...

  3. php AES cbc模式 pkcs7 128位加密解密(微信小程序)

    PHP AES CBC模式PKCS7 128位加密 加密: $key = '1234567812345678'; $iv = '1234567890123456'; $message = '12345 ...

  4. JAVA AES CBC 加密 解密

    AES 256 , KEY 的长度为 32字节(32*8=256bit). AES 128 , KEY 的长度为 16字节(16*8=128bit) CBC 模式需要IV, IV的值是固定写死,还是当 ...

  5. javascript 与 PHP 通信加密,使用AES 128 CBC no padding,以及ios,java,c#文章例子

    运行环境 php7.0 不适用于 php7.0以上版本,因为mcrypt_encrypt()函数已删除 为何要采用 no padding 这种形式: AES加密如果原输入数据不够16字节的整数位,就要 ...

  6. IOS 与 PHP 通信加密,使用AES 128 CBC no padding

    这个网上的资料真实浩如烟海,但是真正有价值的屈指可数 自己尝试了一天多,终于还是搞定了. 再次要感谢网上的前辈么. 比如下面这个关于php和java端的实现: http://my.oschina.ne ...

  7. AES字节数组加密解密流程

    AES类时微软MSDN中最常用的加密类,微软官网也有例子,参考链接:https://docs.microsoft.com/zh-cn/dotnet/api/system.security.crypto ...

  8. python AES 双向对称加密解密

    高级加密标准(Advanced Encryption Standard,AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DES,已经被多方分 ...

  9. Java使用AES算法进行加密解密

    一.加密 /** * 加密 * @param src 源数据字节数组 * @param key 密钥字节数组 * @return 加密后的字节数组 */ public static byte[] En ...

  10. 使用java实现对称加密解密(AES),非对称加密解密(RSA)

    对称加密:双方采用同样的秘钥进行加密和解密.特点是速度快,但是安全性没有非对称加密高 非对称加密:接收方生成的公有秘钥公布给发送方,发送方使用该公有秘钥加密之后,发送给接收方,然后接收方使用私有秘钥解 ...

随机推荐

  1. svn配置及基本使用

    svn软件下载地址http://subversion.apache.org/packages.html在安装TortoiseSVN时安装客户端和服务端 下以svn在windows下使用为例,linux ...

  2. RHEL6 64位ASM方式安装oracle 11gR2(二)

    本文转载自:http://vnimos.blog.51cto.com/2014866/1221377 三.安装数据库软件 1 2 3 4 5 6 7 8 # unzip -d /stage/ linu ...

  3. java代码实现鼠标双击出现画图-----------paint()方法由系统自动调用,且一定是小写的字母p

    总结:在运行过程中,自己不是很认真,没有检查自己写的代码,结果是无论你怎么运行,双击 frame都没用,因为系统根本就没有调用paint()方法绘图.所以很重要的是实现这个方法 package com ...

  4. Java-Maven-Runoob:Maven 引入外部依赖

    ylbtech-Java-Maven-Runoob:Maven 引入外部依赖 1.返回顶部 1. Maven 引入外部依赖 如果我们需要引入第三库文件到项目,该怎么操作呢? pom.xml 的 dep ...

  5. (转) Docker - Docker1.12服务发现,负载均衡和Routing Mesh

    看到一篇介绍 Docker swarm以及如何编排的好文章,挪放到这里,自己学习的同时也分享出来. 原文链接: http://wwwbuild.net/dockerone/414200.html -- ...

  6. 第十九章 MySQL Cluster(待续)

    ··········

  7. Python中特殊函数和表达式 filter,map,reduce,lambda

    1. filter 官方解释:filter(function or None, sequence) -> list, tuple, or string Return those items of ...

  8. Oracle11gR2--静默安装数据库软件

    1.安装相关的包(略) 2.建oracle用户 组 groupadd oinstall --$ORACLE HOME/rdbms/lib/config.c groupadd dba chattr -i ...

  9. C#使用 SharpAVI进行 屏幕录制

    再 nuget 中 搜索 shapAvi 并添加引用 github 地址:https://github.com/baSSiLL/SharpAvi using SharpAvi; using Sharp ...

  10. POJ3624(背包问题)

    1.题目链接地址 http://poj.org/problem?id=3624 2.源代码 #include<iostream> using namespace std; #define ...