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

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo