C语言实现Base64编解码

简介: in_str是输入缓冲区的地址 in_len 要编码的数据的长度 out_str 输出的地址 需要在外面分配内存 unsigned char *out_str = (unsigned char *) malloc (in_len * 4 / 3 + 1); 然后再调用函数编码。
in_str是输入缓冲区的地址
in_len 要编码的数据的长度
out_str 输出的地址
需要在外面分配内存

unsigned char *out_str = (unsigned char *) malloc (in_len * 4 / 3 + 1);

然后再调用函数编码。

void Base64Encode(const unsigned char *in_str, int in_len, unsigned char *out_str)
{ 
static unsigned char base64[] ="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
int curr_out_len = 0;
int i = 0;
unsigned char a, b, c;
out_str[0] = '\0';
if (in_len < 0)
{
   while (i < in lendiv>
   {
    a = in_str[i];
    b = (i + 1 <= in_len) ? 0 : in_str[i + 1];
    c = (i + 2 <= in_len) ? 0 : in_str[i + 2];
    if (i + 2 < in lendiv>
    {
     out_str[curr_out_len++] = (base64[(a << 2) & 0x3F]);
     out_str[curr_out_len++] = (base64[((a < x b >< 4) & 0xf)]);
     out_str[curr_out_len++] = (base64[((b < xc c >< 6) & 0x3)]);
     out_str[curr_out_len++] = (base64[c & 0x3F]);
    }
    else if (i + 1 < in lendiv>
    {
     out_str[curr_out_len++] = (base64[(a << 2) & 0x3F]);
     out_str[curr_out_len++] = (base64[((a < x b >< 4) & 0xf)]);
     out_str[curr_out_len++] = (base64[((b < xc c >< 6) & 0x3)]);
     out_str[curr_out_len++] = '=';
    }
    else
    {
     out_str[curr_out_len++] = (base64[(a << 2) & 0x3F]);
     out_str[curr_out_len++] = (base64[((a < x b >< 4) & 0xf)]);
     out_str[curr_out_len++] = '=';
     out_str[curr_out_len++] = '=';
    }
    i += 3;
   }
   out_str[curr_out_len] = '\0';
}
return;
}


网上的解码函数,都是解码成字符串的,如果解码并保存到文件中,那么往往会多保存几个字节,主要是对base64字符串最后面的=号的判断不够,所以只要自行实现了一下:

void __stdcall Base64DecodeToFile(unsigned char *input, const unsigned char *dst_filename)
{
static int map[256] = {0};
static unsigned char b64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
size_t inplen = strlen(input);
int words = (inplen+3)/4;
size_t i=0, j=0;
int word = 0;
char *p = input;
int padnum = 0;
FILE *fd = NULL;
for (i = 0; i < 64 idiv>
{
   map[(int)b64[i]]=i;
}
if(input[inplen - 1] == '=') padnum = 1;
if(input[inplen - 1] == '=' && input[inplen - 2] == '=') padnum = 2;
fd = fopen(dst_filename,"wb");
if (fd == NULL) return;
for(i=0; i
{
   word = 0;
   word |= map[(int)*p++];
   word < div>
   word |= map[(int)*p++];
   word < div>
   word |= map[(int)*p++];
   word < div>
   word |= map[(int)*p++];
   fprintf(fd, "%c", word << 16 & 0xFF);
   if (i + 1 == words && padnum == 2) 
    break;
   fprintf(fd, "%c", word << 8 & 0xFF);
   if (i + 1 == words && padnum == 1) 
    break;
   fprintf(fd, "%c", word & 0xFF);
}
fclose(fd);
return;
}


目录
相关文章
|
C语言
造轮子之-C语言实现ArrayList
造轮子之-C语言实现ArrayList
|
存储 Linux C语言
生产者消费者模式保姆级教程 (阻塞队列解除耦合性) 一文帮你从C语言版本到C++ 版本, 从理论到实现 (一文足以)
生产者消费者模式保姆级教程 (阻塞队列解除耦合性) 一文帮你从C语言版本到C++ 版本, 从理论到实现 (一文足以)
生产者消费者模式保姆级教程 (阻塞队列解除耦合性) 一文帮你从C语言版本到C++ 版本, 从理论到实现 (一文足以)
|
存储 C语言
c语言实现扫雷(含循环递归展开)
本笔记通过c语言实现扫雷小游戏(包含递归展开) 游戏实现逻辑位于test.c文件,整个游戏头文件位于game.h,游戏进程的具体操作于game.c中实现。
159 0
c语言实现扫雷(含循环递归展开)
|
C语言
c语言实现三子棋(内含阅读思路,简单易实现)
本文如果按顺序来阅读可能不太好接受,建议阅读顺序为,由test.c的逻辑顺序读下去,遇见具体函数的实现跳转到game.c中来理解
125 0
c语言实现三子棋(内含阅读思路,简单易实现)
|
搜索推荐 C语言
【指针进阶三】实现C语言快排函数qsort&回调函数
【指针进阶三】实现C语言快排函数qsort&回调函数
83 0
【指针进阶三】实现C语言快排函数qsort&回调函数
|
C语言
【让你从0到1学会c语言】字符串函数详解及模拟实现(二)
【让你从0到1学会c语言】字符串函数详解及模拟实现(二)
173 0
【让你从0到1学会c语言】字符串函数详解及模拟实现(二)
|
程序员 C语言
【让你从0到1学会c语言】字符串函数详解及模拟实现(一)
【让你从0到1学会c语言】字符串函数详解及模拟实现(一)
105 0
【让你从0到1学会c语言】字符串函数详解及模拟实现(一)
|
C语言
C语言实现学生管理系统(顺序表版)
C语言实现学生管理系统(顺序表版)
158 0
C语言实现学生管理系统(顺序表版)
|
C语言
C语言之回调函数(非常重要)附带回调函数版本实现整型的加减乘除四则运算
C语言之回调函数(非常重要)附带回调函数版本实现整型的加减乘除四则运算
125 0
C语言之回调函数(非常重要)附带回调函数版本实现整型的加减乘除四则运算
|
存储 Java Linux
纯C语言Socket实现聊天室
最近在学习嵌入式开发,练习C语言小项目,基本是参考别人的代码,做了些修改实现了聊天室,纯C语言编写。
272 0
纯C语言Socket实现聊天室