如何从base64解码输出纯ascii?

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

编码的普通纯文本

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;
}
c base64 decoding
1个回答
1
投票

如果您正在解码二进制数据,如下所示,则无法使用

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]);
© www.soinside.com 2019 - 2024. All rights reserved.