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

2023-10-17 00:12

本文主要是介绍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/221657

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected