У меня есть функция, которая декодирует закодированные данные base64 в двоичные данные, но я не знаю, как найти длину декодированных данных. Я использую функции BIO в openssl.
unsigned char *unbase64(unsigned char *input, int length)
{
BIO *b64, *bmem;
unsigned char *buffer = (unsigned char *)malloc(length);
memset(buffer, 0, length);
b64 = BIO_new(BIO_f_base64());
bmem = BIO_new_mem_buf(input, length);
bmem = BIO_push(b64, bmem);
BIO_read(bmem, buffer, length);
BIO_free_all(bmem);
return buffer;
}
Не приводите возвращаемое значение malloc () к C. Компилятору это не нужно, и он может скрыть ошибку.
В Visual C++, по-видимому, требуется преобразование возврата malloc (по крайней мере, в 2010 году). Как ни странно - IDE жалуется, но компилируется.





BIO_read вернет количество прочитанных байтов. В любом случае вам следует проверять возвращаемые значения.
Кстати: вы можете использовать calloc () вместо malloc () + memset ().