编码的普通纯文本
bmVv
解码为neo
没有任何问题,但是这个
AAAAgMom/1a/v0lblO2Ubrt60J2gcuXSljGFQXgcyZWveWLEwo6prwgi3iJIZdodyhKZQrNWp5nKJ3srRXcUW+F1BD3baEVGcmEgqaLZUNBjm057pKRI16kB0YppeGx5qIQ5QjKzsR8ETQbKLNWgRY0QRNVz34kMJR3P/LgHax/6rmf5AAAAAwEAAQ==
编码字符串未解码。只是获取输出缓冲区NULL
/0
。
该字符串解码缓冲区应该是单个字符。如果我这样做,那么我将得到无符号解码 ASCII,但是该 ASCII 代码只是可见和可写的,无法使用编码器再次编码该 ASCII 代码,因为我仍然获得 0
的缓冲区长度。这是因为我使用 printf
和 %c
来输出缓冲区。使用 %s
输出的不是字符串。
我需要将 ASCII 缓冲区输出为字符串。如何在不使用
%c
和 printf
/fwrite
/scanf
/putchar
的情况下将 ASCII 缓冲区输出为字符串?
我期望二进制 ASCII 代码作为字符串再次用于编码。
期待:
��&�V��I[��n�zН�r�Җ1�Axɕ�yb��"�"He���B�V���'{+Ew[�u=�hEFra ���P�c�N{��Hשъixly��9B2��M�,ՠE�D�s߉
%���k��g�
这是我尝试过的base64解码完整代码:
#include <stdio.h>
#include <stdlib.h>
char base64_map[64] = {
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',
'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/'
};
char *base64_decode(char *str)
{
int counts = 0;
char buffer[4];
char *plain = malloc(strlen(str) * 3 / 4 + 1);
int i = 0, p = 0;
for (i = 0; str[i] != '\0'; i++) {
int k;
for (k = 0; k < 64 && base64_map[k] != str[i]; k++);
buffer[counts++] = k;
if (counts == 4) {
plain[p++] = (buffer[0] << 2) + (buffer[1] >> 4);
if (buffer[2] != 64) {
plain[p++] = (buffer[1] << 4) + (buffer[2] >> 2);
}
if (buffer[3] != 64) {
plain[p++] = (buffer[2] << 6) + buffer[3];
}
counts = 0;
}
}
plain[p] = '\0';
return plain;
}
int main()
{
char *str = "AAAAgMom/1a/v0lblO2Ubrt60J2gcuXSljGFQXgcyZWveWLEwo6prwgi3iJIZdodyhKZQrNWp5nKJ3srRXcUW+F1BD3baEVGcmEgqaLZUNBjm057pKRI16kB0YppeGx5qIQ5QjKzsR8ETQbKLNWgRY0QRNVz34kMJR3P/LgHax/6rmf5AAAAAwEAAQ==";
printf("%s", base64_decode(str));
return 0;
}
如果您正在解码二进制数据,如下所示,则无法使用
printf
打印它,因为 printf
将在第一个空字节处停止。
要打印二进制数据,您可以让
base64_decode
函数返回显式长度,然后打印那么多字符。也许是这样的:
int main()
{
char *str = "…";
int len;
char *out = base64_decode(str, &len);
for(int i = 0; i < len; i++) putchar(out[i]);
return 0;
}
要实现这一点,您需要将
base64_decode
的签名重写为
char *base64_decode(char *str, int *lenp)
并添加行
if(lenp != NULL) *lenp = p;
在最后,就在
return plain;
语句之前。
除了循环调用
putchar
,您还可以使用 fwrite
:
char *out = base64_decode(str, &len);
fwrite(out, 1, len, stdout);
并且根据您尝试对输出执行的操作,如果您输出字节的十六进制表示形式,而不是字节本身,则更容易查看(尽管可能不太容易处理):
for(int i = 0; i < len; i++)
printf("%02x", (unsigned char)out[i]);