Base64编码和解码
Base64这是一个二进制编码方法转换成可打印字符。主要用于邮件传输。
Base64将64人物(A-Z,a-z,0-9,+,/)由于基本字符集。把所有的符号转换成字符集。
编码:
编码每次3节转为4字节。若输入字节数不是3的倍数。则在末尾填充0字节使其长度为3的倍数。
对于3字节。每次取出6位,并在前面加入2位0构成一个字节。以此字节为下标查找Base64码表(例如以下图)输出相应字符。
每次将3字节转为4字节(3*8=4*6),直至得到整个输入串的编码结果。最后,若之前在输入中加入了1个0字节,则将输出结果最后1字节替换成“=”,若加入了2个0字节,则将输出结果最后2字节替换成“=”。
解码:
Base64解码就是编码的逆过程,要注意解码时每一个字节的前2位0是人为填充的。后6位才是有效位。每次将4字节中的24位有效位提取出来构成3字节就可以。
编码解码过程的核心就是位操作。
Base64码表
代码:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
const char table[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
int findindex(char c)
{
for(int i=0;i<64;i++)
{
if(c==table[i])
return i;
}
return -1;
}
void base64enc(const char*src,char*&dst)
{
int slen=strlen(src);
int len=slen;
if(len%3!=0)len=(len/3+1)*3;//长度凑成3的倍数
unsigned char*s=(unsigned char*)malloc(len*sizeof(unsigned char));//此处使用unsigned char,否则无法处理中文输入
memset(s,0,len);
memcpy(s,src,slen);
int dlen=(len/3)*4+1;
dst=(char*)malloc(dlen*sizeof(char));
for(int i=0,j=0;i<len;i+=3)
{
//核心步骤
//**************************************
dst[j]=table[s[i]>>2];
dst[j+1]=table[((s[i]&0X03)<<4)|(s[i+1]>>4)];
dst[j+2]=table[((s[i+1]&0X0F)<<2)|(s[i+2]>>6)];
dst[j+3]=table[s[i+2]&0X3F];
//**************************************
j+=4;
}
free(s);
if(slen%3==1)dst[dlen-2]=dst[dlen-3]='=';
if(slen%3==2)dst[dlen-2]='=';
dst[dlen-1]=0;
} void base64dec(const char*src,char*&dst)
{
int slen=strlen(src);
if(slen%4!=0)return ;
int dlen=(slen/4)*3+1;
char*d=(char*)malloc(dlen*sizeof(char));
int index[4];
for(int i=0,j=0;i<slen;i+=4)
{
for(int k=0;k<4;k++)
{
index[k]=findindex(src[i+k]);
}
//核心步骤
//**************************************
d[j]=index[0]<<2|index[1]>>4;
d[j+1]=index[1]<<4|index[2]>>2;
d[j+2]=index[2]<<6|index[3];
//**************************************
j+=3;
}
//去除src尾部'='的影响
if(src[slen-1]=='='&&src[slen]!='=')
dlen-=1;
if(src[slen-1]=='='&&src[slen]=='=')
dlen-=2;
dst=(char*)malloc(dlen*sizeof(char));
memcpy(dst,d,dlen);
free(d);
dst[dlen-1]=0;
}
int main()
{
char src[]="Hello,小罗";
char*enc,*dec;
base64enc(src,enc);
base64dec(enc,dec);
printf("%s\n",src);
printf("%s\n",enc);
printf("%s\n",dec);
free(enc);
free(dec);
return 0;
}
版权声明:本文博主原创文章,博客,未经同意不得转载。
Base64编码和解码的更多相关文章
- BASE64编码和解码(VC源代码) 并 内存加载 CImage 图像
BASE64可以用来将binary的字节序列数据编码成ASCII字符序列构成的文本.完整的BASE64定义可见 RFC1421和 RFC2045.编码后的数据比原始数据略长,为原来的4/3.在电子 ...
- base64编码、解码的C语言实现
转自:http://www.cnblogs.com/yejianfei/archive/2013/04/06/3002838.html base64是一种基于64个可打印字符来表示二进制数据的表示方法 ...
- android Java BASE64编码和解码二:图片的编码和解码
1.准备工作 (1)在项目中集成 Base64 代码,集成方法见第一篇博文:android Java BASE64编码和解码一:基础 (2)添加 ImgHelper 工具类 package com.a ...
- Python中进行Base64编码和解码
Base64编码 广泛应用于MIME协议,作为电子邮件的传输编码,生成的编码可逆,后一两位可能有“=”,生成的编码都是ascii字符.优点:速度快,ascii字符,肉眼不可理解缺点:编码比较长,非常容 ...
- Javascript Base64编码与解码
原文:[转]Javascript Base64编码与解码 <html> <head> <META HTTP-EQUIV="MSThemeCompatible&q ...
- C# base64编码、解码
public class TransferCode { #region base-64编码.解码 /// <summary> /// BASE64编码 /// </summary&g ...
- Url的Base64编码以及解码
Base64可以将二进制转码成可见字符方便进行http传输,但是base64转码时会生成“+”,“/”,“=”这些被URL进行转码的特殊字符,导致两方面数据不一致.我们可以在发送前将“+”,“/”,“ ...
- NET MVC全局异常处理(一) 【转载】网站遭遇DDoS攻击怎么办 使用 HttpRequester 更方便的发起 HTTP 请求 C#文件流。 Url的Base64编码以及解码 C#计算字符串长度,汉字算两个字符 2019周笔记(2.18-2.23) Mysql语句中当前时间不能直接使用C#中的Date.Now传输 Mysql中Count函数的正确使用
NET MVC全局异常处理(一) 目录 .NET MVC全局异常处理 IIS配置 静态错误页配置 .NET错误页配置 程序设置 全局异常配置 .NET MVC全局异常处理 一直知道有.NET有相关 ...
- js的Base64编码与解码
js的Base64编码与解码 pc和手机app项目中,经常需要将手机自带的表情图片转换特定的编码格式与后台进行交互. Base64其实是一种简单的置换加密方式,但是BASE64的用处往往并不是为了防止 ...
- 在Java中如何进行BASE64编码和解码
在Java中如何进行BASE64编码和解码 //在Java中如何进行BASE64编码和解码 package me.xzh.study.sun.misc.BASE64; import sun.misc. ...
随机推荐
- Vsphere client 无法登陆VCenter 处理的方法
上周做安全的时候将DC.DB和VCenter 三台机器的防火墙都启用了,结果Vcenter 登陆的时候总是提示服务器没有响应,连web client 都无法登陆. 处理过程 一.首先要保证 vmvar ...
- SE 2014年5月23日
两站点 A 和 B,由于业务往来需要,所以工程师提出vpn技术,同时需要保证业务流在internet上的安全性,同时在这里站点均为固定ip地址. 通过分析以上信息,确定这里使用 IPSec VPN的主 ...
- PHP移动互联网开发笔记(2)——变量及常量
原文地址:http://www.php100.com/html/php/rumen/2014/0326/6703.html 一.PHP5.4的基本的语法格式 1.PHP的切割符 view source ...
- CMD经常使用的命令
Win7Excuting订单 win+R.运行该快捷方式.下面3一个人必须知道: ping 它是用来检查网络是否通畅或者网络连接速度的命令. 作为一个生活在网络上的管理员或者黑客来说,ping命令是第 ...
- hdu1520 (树形dp)
hdu1520 http://acm.hdu.edu.cn/showproblem.php?pid=1520 题意是给定一棵树,每个结点有一个价值,要我们选择任意个结点使得总价值最大,规则是如果父亲结 ...
- 行人检测(Pedestrian Detection)资源整合
一.纸 评论文章分类: [1] D. Geronimo, and A. M.Lopez. Vision-based Pedestrian Protection Systems for Intellig ...
- POJ培训计划2253_Frogger(最短/floyd)
解决报告 意甲冠军: 乞讨0至1所有最大的道路值的最小数量. 思维: floyd. #include <iostream> #include <cstdio> #include ...
- PHP --字符串编码转换(自动识别原编码)
/** * 对数据进行编码转换 * @param array/string $data 数组 * @param string $output 转换后的编码 */ function array_icon ...
- C语言程序代写(qq:928900200)
1cs3157 – Advanced ProgrammingSummer 2014, Project 1, 150 pointsJune 17, 2014Follow these step-by-st ...
- AndroidUI的组成部分GridView
java 代码例如以下(简单的知识点我会以凝视的形式解说): package com.gc.gridviewdemo; /** * @author Android将军 */ /** * 知识点解说: ...