免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1409 | 回复: 0
打印 上一主题 下一主题

base64编码解码 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-01 16:10 |只看该作者 |倒序浏览


文件:
base64.tar
大小:
10KB
下载:
下载
base64编码解码

#include string.h>
#include stdio.h>
#include stdlib.h>
void encode(char *src, int src_len, char *dst)
{
        int i = 0, j = 0;
        char base64_map[65] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
        for (; i  src_len - src_len % 3; i += 3) {
                dst[j++] = base64_map[(src >> 2) & 0x3F];
                dst[j++] = base64_map[((src  4) & 0x30) + ((src[i + 1] >> 4) & 0xF)];
                dst[j++] = base64_map[((src[i + 1]  2) & 0x3C) + ((src[i + 2] >> 6) & 0x3)];
                dst[j++] = base64_map[src[i + 2] & 0x3F];
        }
        if (src_len % 3 == 1) {
                dst[j++] = base64_map[(src >> 2) & 0x3F];
                dst[j++] = base64_map[(src  4) & 0x30];
                dst[j++] = '=';
                dst[j++] = '=';
        }
        else if (src_len % 3 == 2) {
                dst[j++] = base64_map[(src >> 2) & 0x3F];
                dst[j++] = base64_map[((src  4) & 0x30) + ((src[i + 1] >> 4) & 0xF)];
                dst[j++] = base64_map[(src[i + 1]  2) & 0x3C];
                dst[j++] = '=';
        }
        dst[j] = '\0';
}
void decode(char *src, int src_len, char *dst)
{
        int i = 0, j = 0;
        char base64_decode_map[256] = {
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 62, 255, 255, 255, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 255, 255,
                255, 0, 255, 255, 255, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
                15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 255, 255, 255, 255, 255, 255, 26, 27, 28,
                29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
                49, 50, 51, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
                255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255};
        for (; i  src_len; i += 4) {
                dst[j++] = base64_decode_map[src]  2 |
                        base64_decode_map[src[i + 1]] >> 4;
                dst[j++] = base64_decode_map[src[i + 1]]  4 |
                        base64_decode_map[src[i + 2]] >> 2;
                dst[j++] = base64_decode_map[src[i + 2]]  6 |
                        base64_decode_map[src[i + 3]];
        }
        dst[j] = '\0';
}
int main( int argc, char* argv[])
{
        int i,size;
        unsigned char input[1024] = {'\0'};
        unsigned char output[1024] = {'\0'};
        if (argc = 2)
        {
                printf("Usage: string encode and decode.\n");
                printf("\t\tbase64 -e decode string\t\tencode string.\n");
                printf("\t\tbase64 -d encode string\t\tdecode string.\n");
                exit(1);
        }
        size = strlen(argv[2]);
        strncpy(input, argv[2], size);
        printf("需要进行处理的数据: \n", input);
        if (!strncmp(argv[1], "-e", 2))
        {
                encode(input, size, output);
                printf("base64编码后的数据: \n", output);
        }
        else if (!strncmp(argv[1], "-d", 2))
        {
                decode(input, size, output);
                printf("base64解码后的数据: \n", output);
        }
        return 0;
}


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u3/91335/showart_2108568.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP