void AesEcb256Pkcs7Encrypt(u8 *input, u8 *outhex, u8 *key, int len)
TRACE("input:%s, key:%s, %d\n", (char*)input, (char*)key, len);
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);
for (size_t i = 0; i < len; ++i)
sprintf(hex, "%02X", outhex[i]);
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());
void AesEcb256Pkcs7Decrypt(unsigned char* input, unsigned char* output, unsigned char* key, int len)
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);
for (size_t i = 0; i < len; ++i)
sprintf(hex, "%02X", output[i]);
TRACE("output[%d]:%s [%d]\n", i, hex, output[i]);
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;
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");
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);
u8 *key = "171ce897ad494cb289b023cd3c0ceab4";
char plaintext[256] = {0};
unsigned char ciphertext[1024];
unsigned char output[1024];
sprintf(plaintext, "{\"terminalNumber\":\"28b7f2eb-b549-3200-9950-2c6a83cd8af2\"}");
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);
int plaintext_len = Pkcs7Unpadding(output, allLen);
TRACE("AES Decrypt err\n");
TRACE("output:%s [%d]\n\n", output, plaintext_len);


