AES加密0x00字符的问题

问题描述 投票:1回答:1

我目前正在使用AES-128(使用tiny-aes-c)加密文件的程序。我的第一个包含\ 0的数组有问题:

uint8_t in[16] = {0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a, 0x00, 0x00, 0x00, 0x0d, 0x49, 0x48, 0x44, 0x52};
uint8_t key[16] = "ABCDEFGHIJKLMNOP";
uint8_t iv[16] = { 0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff };

struct AES_ctx ctx;
AES_init_ctx_iv(&ctx, key, iv);
AES_CTR_xcrypt_buffer(&ctx, in, strlen((char*)in));
printf("\nENCODED:      %s", (char*)in);
/*Another print for hex values*/

[按预期,只有左侧部分被加密,其余部分消失。我应该如何纠正这个问题?谢谢。

c encryption aes
1个回答
2
投票

[您正在使用strlen(in),它计数到第一个空字节(0x00),在这种情况下,它返回8,而不是缓冲区的全长(16)。

要更正,请通过其他方法确定缓冲区的长度。在这里您已经知道它是16。您may在此处使用sizeof(in),例如:]]

uint8_t in[16] = {0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a, 0x00, 0x00, 0x00, 0x0d, 0x49, 0x48, 0x44, 0x52};
uint8_t key[16] = "ABCDEFGHIJKLMNOP";
uint8_t iv[16] = { 0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfd, 0xfe, 0xff };

struct AES_ctx ctx;
AES_init_ctx_iv(&ctx, key, iv);
AES_CTR_xcrypt_buffer(&ctx, in, sizeof(in));

但是如果您重写可变长度数组的代码,这将不起作用。在这种情况下,您应该将长度作为附加参数传递。

© www.soinside.com 2019 - 2024. All rights reserved.