Base64编码的原理及C++实现代码
2018-07-20 来源:open-open
Base64编码在邮件中最为常见,呵呵,因为我最近就是在做邮箱报警,SMTP验证就是Base64编码用户名和密码进行验证的,并且图片为附件也是要 转换成base64编码的数据,然后再发送的。该编码使用64个明文来编码任意的二进制文件,它里面只使用了A-Z,a-z,0-9,+,/这64个字 符。编码里面还有“=”号啊,不过等号不属于编码字符,而是填充字符。
我在网上查了很多关于Base64编码代码,大都比较的复杂和冗长,所以,就自己按照原理写了一个。
base64编码原理:
1)base64的编码都是按字符串长度,以每3个8bit的字符为一组,
2)然后针对每组,首先获取每个字符的ASCII编码,
3)然后将ASCII编码转换成8bit的二进制,得到一组3*8=24bit的字节
4)然后再将这24bit划分为4个6bit的字节,并在每个6bit的字节前面都填两个高位0,得到4个8bit的字节
5)然后将这4个8bit的字节转换成10进制,对照Base64编码表 ,得到对应编码后的字符。
我在网上查了很多关于Base64编码代码,大都比较的复杂和冗长,所以,就自己按照原理写了一个。
base64编码原理:
1)base64的编码都是按字符串长度,以每3个8bit的字符为一组,
2)然后针对每组,首先获取每个字符的ASCII编码,
3)然后将ASCII编码转换成8bit的二进制,得到一组3*8=24bit的字节
4)然后再将这24bit划分为4个6bit的字节,并在每个6bit的字节前面都填两个高位0,得到4个8bit的字节
5)然后将这4个8bit的字节转换成10进制,对照Base64编码表 ,得到对应编码后的字符。
static const char* base64_chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; //chsrc为源数据,chdes为Base64编码后的数据,len为数据长度 void Base64_Code(unsigned char* chsrc, unsigned char* chdes, int len) { unsigned char char_array_3[3], char_array_4[4]; int i = 0, j = 0; while(len--) { char_array_3[i++] = *(chsrc++); if(3 == i) { char_array_4[0] = (char_array_3[0] & 0xfc) >> 2; char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4); char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6); char_array_4[3] = char_array_3[2] & 0x3f; for(i = 0; i < 4; i++) *(chdes+i) = base64_chars[char_array_4[i]]; i = 0; chdes += 4; } } if(i) { for(j = i; j < 3; j++) char_array_3[j] = '\0'; char_array_4[0] = (char_array_3[0] & 0xfc) >> 2; char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4); char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6); char_array_4[3] = char_array_3[2] & 0x3f; for(j = 0; j < (i+1); j++) *(chdes++) = base64_chars[char_array_4[j]]; while((3 > i++)) *(chdes++) = '='; } *chdes = '\0'; return; }
标签: 代码
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点!
本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。
上一篇:C++内存池实现(非线程安全)
最新资讯
热门推荐