OpenSSL之AES加解密API使用
2016-01-05 17:11
543 查看
#include "openssl/aes.h"
#pragma comment(lib, "libeay32.lib")
int main(int argc, char* argv[])
{
//1.定义加解密密钥
//加密秘钥 测试用所以简单,如果暴露了该秘钥及加密算法 则可破解!
const unsigned char* userkey = (const unsigned char*)"0123456789012345";
//2.生成加密/解密AES_KEY
AES_KEY encKey;//加密KEY
AES_KEY decKey;//解密KEY
//生成加密KEY
AES_set_encrypt_key(userkey,128,&encKey);
//生成解密KEY
AES_set_decrypt_key(userkey,128,&decKey);
const unsigned char* in = (const unsigned char*)"中华人民共和国";
unsigned char out[256] = {0};
unsigned char out2[256] = {0};
//3.加密 每16字节为一组 输出长度为16字节整数倍
int len = strlen((const char*)in);
int n = len/16;;
if (len%16>0)
n++;
for (int i=0;i<n;i++)
{
//等价于AES_encrypt(in+i*16,out+i*16,&key);
AES_ecb_encrypt(in+i*16,out+i*16,&encKey,AES_ENCRYPT);
}
//4.解密 每16字节为一组
//把加密的输出当做解密的输入
len = strlen((const char*)out);
n = len/16;;
if (len%16>0)
n++;
for (int i=0;i<n;i++)
{
//等价于AES_decrypt(out+i*16,out2+i*16,&key2);
AES_ecb_encrypt(out+i*16,out2+i*16,&decKey,AES_DECRYPT);
}
//5.输出结果
printf("输入内容=%s len=%d\n",in,strlen((const char*)in));
printf("加密内容=%s len=%d\n",out,strlen((const char*)out));
printf("解密内容=%s len=%d\n",out2,strlen((const char*)out2));
/*
输入内容=中华人民共和国 len=14
加密内容="64 be e0 1b bd fd 65 e4 71 6d 45 80 12 ab 70 04" len=16
解密内容=中华人民共和国 len=14
*/
return 0;
}
#include "openssl/aes.h"
#pragma comment(lib, "libeay32.lib")
int main(int argc, char* argv[])
{
//1.定义加解密密钥
//加密秘钥 测试用所以简单,如果暴露了该秘钥及加密算法 则可破解!
const unsigned char* userkey = (const unsigned char*)"0123456789012345";
//2.生成加密/解密AES_KEY
AES_KEY encKey;//加密KEY
AES_KEY decKey;//解密KEY
//生成加密KEY
AES_set_encrypt_key(userkey,128,&encKey);
//生成解密KEY
AES_set_decrypt_key(userkey,128,&decKey);
const unsigned char* in = (const unsigned char*)"中华人民共和国";
unsigned char out[256] = {0};
unsigned char out2[256] = {0};
//3.加密 每16字节为一组 输出长度为16字节整数倍
int len = strlen((const char*)in);
int n = len/16;;
if (len%16>0)
n++;
for (int i=0;i<n;i++)
{
//等价于AES_encrypt(in+i*16,out+i*16,&key);
AES_ecb_encrypt(in+i*16,out+i*16,&encKey,AES_ENCRYPT);
}
//4.解密 每16字节为一组
//把加密的输出当做解密的输入
len = strlen((const char*)out);
n = len/16;;
if (len%16>0)
n++;
for (int i=0;i<n;i++)
{
//等价于AES_decrypt(out+i*16,out2+i*16,&key2);
AES_ecb_encrypt(out+i*16,out2+i*16,&decKey,AES_DECRYPT);
}
//5.输出结果
printf("输入内容=%s len=%d\n",in,strlen((const char*)in));
printf("加密内容=%s len=%d\n",out,strlen((const char*)out));
printf("解密内容=%s len=%d\n",out2,strlen((const char*)out2));
/*
输入内容=中华人民共和国 len=14
加密内容="64 be e0 1b bd fd 65 e4 71 6d 45 80 12 ab 70 04" len=16
解密内容=中华人民共和国 len=14
*/
return 0;
}
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C++联合体转换成C#结构的实现方法
- C++高级程序员成长之路
- C++编写简单的打靶游戏
- C++ 自定义控件的移植问题
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- 使用Lua来扩展C++程序的方法
- C++中调用Lua函数实例
- Lua和C++的通信流程代码实例
- C与C++之间相互调用实例方法讲解
- 解析C++中派生的概念以及派生类成员的访问属性