C++使用openssl对AES-256-ECB PKCS7 加解密

2023-11-25 08:20

本文主要是介绍C++使用openssl对AES-256-ECB PKCS7 加解密,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


/** AES-256-ECB PKCS7 加密 函数* input:经过PKCS7填充后的明文数据* outhex:加密后的命名数据16进制数,可以使用base64_encode转换为base64格式字符串密文* key:密钥* len:经过PKCS7填充后的明文数据长度*/
void AesEcb256Pkcs7Encrypt(u8 *input, u8 *outhex, u8 *key, int len)
{/* key:171ce897ad494cb289b023cd3c0ceab4 * input:{terminalNumber}* aesHexStr:6241579fb24b00f9d1d238ed191e700877b27ba4e7f6184253eb40c20f67390f* base64str:YkFXn7JLAPnR0jjtGR5wCHeye6Tn9hhCU+tAwg9nOQ8=** input:{"terminalNumber":"28b7f2eb-b549-3200-9950-2c6a83cd8af2"}* aesHexStr:3B2EFE3D4BF2E586F06D9AC26B2F35CE67B2B228C5DE89980DE8CE3570EBBEE62EB54526A24542885D8902E860D54D056C6545D183B0A0134A48449C3D9F7B19* base64str:Oy7+PUvy5YbwbZrCay81zmeysijF3omYDejONXDrvuYutUUmokVCiF2JAuhg1U0FbGVF0YOwoBNKSEScPZ97GQ==*/TRACE("input:%s, key:%s, %d\n", (char*)input, (char*)key, len);AES_KEY aesKey;AES_set_encrypt_key(key, 256, &aesKey);for (size_t i = 0; i < len; i += AES_BLOCK_SIZE){AES_encrypt(input + i, outhex + i, &aesKey);TRACE("i:%d\n\n", i);}/* 将加密后的数据转换成十六进制字符串 */std::string aesHexStr;for (size_t i = 0; i < len; ++i){char hex[3];sprintf(hex, "%02X", outhex[i]);aesHexStr += hex;}/* 将hex转为base64 */char base64str[2*len] = {0};base64_encode(outhex, base64str, len);TRACE("buf[%s], len:%d, hexAes[%s], len:%d\n", base64str, strlen(base64str), aesHexStr.data(), aesHexStr.length());
}

/** AES-256-ECB PKCS7 解密 函数*/
void AesEcb256Pkcs7Decrypt(unsigned char* input, unsigned char* output, unsigned char* key, int len)
{AES_KEY aesKey;AES_set_decrypt_key(key, 256, &aesKey);for (size_t i = 0; i < len; i += AES_BLOCK_SIZE){AES_decrypt(input + i, output + i, &aesKey);TRACE("i:%d\n\n", i);}/* 将加密后的数据转换成十六进制字符串 */std::string aesHexStr;for (size_t i = 0; i < len; ++i){char hex[3];sprintf(hex, "%02X", output[i]);aesHexStr += hex;TRACE("output[%d]:%s [%d]\n", i, hex, output[i]);}
}

// PKCS7填充函数
int Pkcs7Padding(char *data, int len)
{int padding_len = AES_BLOCK_SIZE - (len % AES_BLOCK_SIZE);TRACE("data:%s, len:%d, padding_len:%d \n\n", data, len, padding_len);for (int i = 0; i < padding_len; i++){data[len + i] = (char)padding_len;}return len + padding_len;
}//去除PKCS7填充
int Pkcs7Unpadding(unsigned char *data, int length) 
{/* 取出最后一个字节数据 */int padding_size = data[length - 1];TRACE("padding_size:%d ,%d ,%d\n\n", padding_size, data[length - 1], length);if (padding_size > AES_BLOCK_SIZE || padding_size == 0) {TRACE("padding err\n\n");return -1; // 非法填充}int padding_index = length - padding_size;for (int i = 0; i < padding_size; i++){if (data[padding_index+i] != (unsigned char)padding_size){TRACE("padding err :%d ,%d\n\n", data[padding_index+i], padding_size);return -1; // 非法填充}}return padding_index;
}
int maintest()
{/* 256位密钥 */u8 *key = "171ce897ad494cb289b023cd3c0ceab4";char plaintext[256] = {0};/* 加密密文hex */unsigned char ciphertext[1024];unsigned char output[1024]; // 解密输出//sprintf(plaintext, "terminalNumber");//sprintf(plaintext, "{terminalNumber}");sprintf(plaintext, "{\"terminalNumber\":\"28b7f2eb-b549-3200-9950-2c6a83cd8af2\"}");/* PKCS7填充明文 */int allLen = Pkcs7Padding((char *)plaintext, strlen(plaintext));/* 加密 */AesEcb256Pkcs7Encrypt(plaintext, ciphertext, key, allLen);TRACE("plaintext:%s, len:%d key:%s \n\n", plaintext, allLen, key);/* 解密 */AesEcb256Pkcs7Decrypt(ciphertext, output, key, allLen);/* PKCS7解填充 */int plaintext_len = Pkcs7Unpadding(output, allLen); if (plaintext_len == -1){TRACE("AES Decrypt err\n");}else{TRACE("output:%s [%d]\n\n", output, plaintext_len);}return 0;
}

这篇关于C++使用openssl对AES-256-ECB PKCS7 加解密的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/423452

相关文章

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方