Rijndael用法,如何填充数据
这几天客户要求数据加密,算法是Rijndael,于是从网上找来别人写好的算法代码整合到项目。具体怎么找,大家自己搜吧,关键字是Rijndael c++。下载下来之后,发现人家的例子里需要加密的数据都是16字节的整数倍。但我们需要加密的东西哪里这么好,刚好是16的整数倍。后来找到其他资料说不够16整数倍的部分要填充数据。我测试了一下,填充0,结果和C#里的加密结果不一样,郁闷死了。这时候真羡慕搞C#的同学,啥都包装好了,不用自己找代码。
一次一次试肯定可以试对结果,但效率是不是太低了点?所以我把C#加密后的结果弄出来,用CRijndael去解密,最后发现应该怎么填充数据了。话不多说,代码如下,希望能给其他同学带来一些便利,N年来第一次回报其他码农兄弟。
强调一下,key最长只能是32字节,IV最大只有16字节,MY_KEY和MY_IV过长的话,运行不通过,所以代码对这个做了限制。
//Test.cpp
#include "Rijndael.h"
#include <iostream>
#include <atlenc.h>
using namespace std;
#define DEFAULT_BLOCK_SIZE 16
#define MAX_KEY_LEN 32
#define MAX_IV_LEN 16
#define MY_KEY "UFCy76*h%(HilJ$lhj!y6&(*jkP87jH7"
#