c++ DES ECB加密算法pkcs5padding填充实现

2024-02-11 12:18

本文主要是介绍c++ DES ECB加密算法pkcs5padding填充实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我主要的实现的pkcs5padding填充,其他填充方式自己实现就好了,都不难。

使用的是静态连接的方法,使用的是openssl的libcrypto库,网上一大堆,这里就不贴了。

windows库:https://download.csdn.net/download/suhiymof/11247287

头文件这样包含即可:

#ifdef WIN32
#include "des.h"
#pragma comment(lib, "libcrypt" )
#else
#include "openssl/des.h"
#endif //  WIN32

填充代码

//填充
char* PKCS5Padding(string strParams, uint32 unBlockSize)
{int nRaw_size = strParams.size();int i=0, j=nRaw_size/8+1, k=nRaw_size%8;int nPidding_size = 8 - k;char* szArray;szArray = (char *)malloc(nRaw_size + nPidding_size);memcpy(szArray, strParams.c_str(), nRaw_size);for (int i1=nRaw_size; i1<(nRaw_size+nPidding_size); i1++) {// PKCS5Padding 算法:szArray[i1] = nPidding_size;}return szArray;
}

windows加密:

//strParams:加密字符串
//szKey:加密的密码,我用的是八字节的密码
string Des_Encrypt(string strParams, char* szKey)
{using namespace CryptoPP;char szCommand[1024];memset(szCommand, 0, 1024);int nRaw_size = strParams.size();char* szArray = PKCS5Padding(strParams, DES::BLOCKSIZE);int j=nRaw_size/DES::BLOCKSIZE + 1;unsigned char key[DES::DEFAULT_KEYLENGTH];memcpy(key, szKey, DES::BLOCKSIZE);unsigned char szInput[ DES::BLOCKSIZE];unsigned char szOutput[ DES::BLOCKSIZE];for (int i = 0; i < j; ++i){memset(szInput, 0, 8);memset(szOutput, 0, 8);memcpy(szInput, szArray+(i*8), 8);DESEncryption encryption_DES;//因此,设置密匙。encryption_DES.SetKey(key, DES::KEYLENGTH );//进行加密encryption_DES.ProcessBlock( szInput, szOutput);memcpy(szCommand+(i*8), szOutput, 8);}int nLen = j * 8;//base64编码std::string strTmp = base64_encode(reinterpret_cast<const unsigned char*>(szCommand), nLen);return strTmp;
}

linux加密:

string Des_Encrypt(string strParams, char* szKey)
{char szCommand[1024];memset(szCommand, 0, 1024);int nRaw_size = strParams.size();char* szArray = PKCS5Padding(strParams, sizeof(DES_cblock));int j=nRaw_size/8 + 1;DES_cblock sKey;// = "12341234";memcpy(sKey, szKey, 8);const_DES_cblock sInput;DES_cblock sOutput;DES_key_schedule sSchedule;//转换成scheduleDES_set_key_unchecked(&sKey, &sSchedule); for (int i = 0; i < j; ++i){memset(sInput, 0, 8);memset(sOutput, 0, 8);memcpy(sInput, szArray+(i*8), 8);DES_ecb_encrypt(&sInput, &sOutput, &sSchedule, DES_ENCRYPT);memcpy(szCommand+(i*8), sOutput, 8);}int nLen = j * 8;//base64编码std::string strTmp = base64_encode(reinterpret_cast<const unsigned char*>(szCommand), nLen);return strTmp;
}

这里包含了base64位编码,这里贴一下源码

static const std::string base64_chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ""abcdefghijklmnopqrstuvwxyz""0123456789+/";static inline bool is_base64(unsigned char c) {return (isalnum(c) || (c == '+') || (c == '/'));
}std::string base64_encode(unsigned char const* bytes_to_encode, unsigned int in_len) {printf("---%d\n", in_len);std::string ret;int i = 0;int j = 0;unsigned char char_array_3[3];unsigned char char_array_4[4];while (in_len--) {char_array_3[i++] = *(bytes_to_encode++);if (i == 3) {char_array_4[0] = (char_array_3[0] & 0xfc) >> 2;char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4);char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);char_array_4[3] = char_array_3[2] & 0x3f;for(i = 0; (i <4) ; i++)ret += base64_chars[char_array_4[i]];i = 0;}}if (i){for(j = i; j < 3; j++)char_array_3[j] = '\0';char_array_4[0] = (char_array_3[0] & 0xfc) >> 2;char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4);char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);char_array_4[3] = char_array_3[2] & 0x3f;for (j = 0; (j < i + 1); j++)ret += base64_chars[char_array_4[j]];while((i++ < 3))ret += '=';}//printf("---111%d, %s\n", ret.size(), ret.c_str());return ret;}std::string base64_decode(std::string const& encoded_string) {size_t in_len = encoded_string.size();int i = 0;int j = 0;int in_ = 0;unsigned char char_array_4[4], char_array_3[3];std::string ret;while (in_len-- && ( encoded_string[in_] != '=') && is_base64(encoded_string[in_])) {char_array_4[i++] = encoded_string[in_]; in_++;if (i ==4) {for (i = 0; i <4; i++)char_array_4[i] = base64_chars.find(char_array_4[i]);char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4);char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2);char_array_3[2] = ((char_array_4[2] & 0x3) << 6) + char_array_4[3];for (i = 0; (i < 3); i++)ret += char_array_3[i];i = 0;}}if (i) {for (j = i; j <4; j++)char_array_4[j] = 0;for (j = 0; j <4; j++)char_array_4[j] = base64_chars.find(char_array_4[j]);char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4);char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2);char_array_3[2] = ((char_array_4[2] & 0x3) << 6) + char_array_4[3];for (j = 0; (j < i - 1); j++) ret += char_array_3[j];}return ret;
}

解密:

windows

string Des_Decrypt(std::string strEncryptData, char* szKey)
{using namespace CryptoPP;//base64解码strEncryptData = base64_decode(strEncryptData);string strRet;std::vector<unsigned char> vecCleartext;int nRaw_size = strEncryptData.length();int j=nRaw_size/DES::BLOCKSIZE;unsigned char key[DES::DEFAULT_KEYLENGTH];memcpy(key, szKey, DES::BLOCKSIZE);unsigned char szInput[ DES::BLOCKSIZE];unsigned char szOutput[ DES::BLOCKSIZE];const char* szData = strEncryptData.c_str();//解密for (int i = 0; i < j; ++i){memset(szInput, 0, DES::BLOCKSIZE);memset(szOutput, 0, DES::BLOCKSIZE);memcpy(szInput, szData+(i*DES::BLOCKSIZE), DES::BLOCKSIZE);DESDecryption decryption_DES;//回忆一下之前的背景,对称加密算法需要一个密匙。加密和解密都会用到。//因此,设置密匙。decryption_DES.SetKey(key, DES::KEYLENGTH );//进行加密decryption_DES.ProcessBlock(szInput, szOutput);for (int k = 0; k < DES::BLOCKSIZE; k++)vecCleartext.push_back(szOutput[k]);}//填充数量int nPadNum = vecCleartext[nRaw_size-1];strRet.clear();strRet.assign(vecCleartext.begin(), vecCleartext.end()-nPadNum);return strRet;
}

linux:

string Des_Decrypt(std::string strEncryptData, char* szKey)
{//base64解码strEncryptData = base64_decode(strEncryptData);string strRet;std::vector<unsigned char> vecCleartext;DES_cblock sKey;memcpy(sKey, szKey, 8);DES_key_schedule sSchedule;//转换成scheduleDES_set_key_unchecked(&sKey, &sSchedule); const_DES_cblock sInput;DES_cblock sOutput;int nRaw_size = strEncryptData.length();int j=nRaw_size/8;const char* szData = strEncryptData.c_str();//解密unsigned char szTmp[8];for (int i = 0; i < j; ++i){memset(sInput, 0, 8);memset(sOutput, 0, 8);memcpy(sInput, szData+(i*8), 8);DES_ecb_encrypt(&sInput, &sOutput, &sSchedule, DES_DECRYPT);for (int k = 0; k < 8; k++)vecCleartext.push_back(sOutput[k]);}//填充数量int nPadNum = vecCleartext[nRaw_size-1];strRet.clear();strRet.assign(vecCleartext.begin(), vecCleartext.end()-nPadNum);return strRet;
}

 

这篇关于c++ DES ECB加密算法pkcs5padding填充实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库