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

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、