C++-openssl-aes-cbc-pkcs5

PKCS#5填充是PKCS#7填充的一个子集,在PKCS#7填充时BlockSize为8的时候,PKCS#5与PKCS#7填充是一样的,在BlockSize不同时PKCS#5与PKCS#7填充是不同的。

PKCS#5填充是将数据填充到8的倍数,

填充后数据长度的计算公式:

定于元数据长度为x,

填充后的长度是 x + (8 - (x % 8)),

填充的数据是 8 - (x % 8)

示例:

1byte

数据数 0x41

填充前:0x41

填充后:0x410x070x070x070x070x070x070x07

2byte

数据数 0x41

填充前:0x410x41

填充后:0x410x410x060x060x060x060x060x06

3byte

数据数 0x41

填充前:0x410x410x41

填充后:0x410x410x410x050x050x050x050x05

4byte

数据数 0x41

填充前:0x410x410x410x41

填充后:0x410x410x410x410x040x040x040x04

5byte

数据数 0x41

填充前:0x410x410x410x410x41

填充后:0x410x410x410x410x410x030x030x03

6byte

数据数 0x41

填充前:0x410x410x410x410x410x41

填充后:0x410x410x410x410x410x410x020x02

7byte

数据数 0x41

填充前:0x410x410x410x410x410x410x41

填充后:0x410x410x410x410x410x410x410x01

8byte

数据数 0x41

填充前:0x410x410x410x410x410x410x410x41

填充后:0x410x410x410x410x410x410x410x410x080x080x080x080x080x080x080x08

以下是c++代码

cpp 复制代码
unsigned char* test_pkcs5padding(unsigned char* in,  int m_BlockSize)
{
    int inlen = strlen((char*)in);            //1.获取输入长度
    int outlen = inlen + (8 - (inlen % 8));   //2.计算输出长度
    unsigned char* out = new unsigned char[outlen];          //3.创建输出buf
    memcpy(out, in, inlen);                   //4.out 
    for (int i = inlen; i < outlen; i++)      //5.填充out 中剩余的位数
    {
        int paddingval = (outlen - (inlen % 8));
        out[i] = paddingval;
    }
    return out;
}
cpp 复制代码
     test_main()
{

    int m_BlockSize = 8;
    unsigned char in[]="A";
    unsigned char *out=NULL;
    out=test_pkcs5padding(in, 8);
    unsigned char in2[] ="AA";
    out=test_pkcs5padding(in2,8);
    unsigned char in3[] = "AAA";
    out = test_pkcs5padding(in3,8);
    unsigned char in8[] = "AAAAAAAA";
    out = test_pkcs5padding(in8, 8);
    
}
cpp 复制代码
public byte[] pkcs5_padding(byte[] source) {
        int sourceLength = source.length;
        int paddingLength = sourceLength  + (8- (sourceLength % 8));
        byte[] paddingResult = new byte[paddingLength];
        System.arrayCopy(source, 0, paddingResult, 0, sourceLength);
        for (int i = sourceLength; i < paddingLength; i++) {
            paddingResult[i] = (byte)(paddingLength - (sourceLength % 8);
        }
        return paddingResult;
    }
相关推荐
江公望4 分钟前
Qt QML实现无边框窗口
开发语言·qt
深耕AI6 分钟前
【MFC典型类和函数:CString的字符串魔法与Afx全局函数的便利店】
c++·mfc
怀旧,9 分钟前
【C++】19. 封装红⿊树实现set和map
linux·c++·算法
凯子坚持 c18 分钟前
Redis核心通用命令深度解析:结合C++ redis-plus-plus 实战指南
c++·redis·log4j
秦禹辰27 分钟前
宝塔面板安装MySQL数据库并通过内网穿透工具实现公网远程访问
开发语言·后端·golang
黄焖鸡能干四碗32 分钟前
智慧教育,智慧校园,智慧安防学校建设解决方案(PPT+WORD)
java·大数据·开发语言·数据库·人工智能
神里流~霜灭40 分钟前
(C++)数据结构初阶(顺序表的实现)
linux·c语言·数据结构·c++·算法·顺序表·单链表
John_ToDebug1 小时前
从源码视角全面解析 Chrome UI 布局系统及 Views 框架的定制化实现方法与实践经验
c++·chrome·架构
一只乔哇噻1 小时前
java后端工程师进修ing(研一版 || day41)
java·开发语言·学习·算法
愚润求学1 小时前
【贪心算法】day7
c++·算法·leetcode·贪心算法