C++实现图片的base64编码

from:http://blog.csdn.net/hei_ya/article/details/51637929

1.base64编码的原因

网络传送渠道并不支持所有的字节,例如传统的邮件只支持可见字符的传送,像ASCII码的控制字符就不能通过邮件传送。这样用途就受到了很大的限制,比如图片二进制流的每个字节不可能全部是可见字符,所以就传送不了。最好的方法就是在不改变传统协议的情 况下,做一种扩展方案来支持二进制文件的传送。把不可打印的字符也能用可打印字符来表示,问题就解决了。Base64编码应运而生,Base64就是一种 基于64个可打印字符来表示二进制数据的表示方法。

2.base64编码原理

 Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24 位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。


ZBase64.h

[cpp] view plain copy
  1. <span style="font-size:18px;">#include <string>  
  2. using namespace std;  
  3.   
  4. class ZBase64  
  5. {  
  6. public:  
  7.     /*编码 
  8.     DataByte 
  9.         [in]输入的数据长度,以字节为单位 
  10.     */  
  11.     string Encode(const unsigned char* Data,int DataByte);  
  12.     /*解码 
  13.     DataByte 
  14.         [in]输入的数据长度,以字节为单位 
  15.     OutByte 
  16.         [out]输出的数据长度,以字节为单位,请不要通过返回值计算 
  17.         输出数据的长度 
  18.     */  
  19.     string Decode(const char* Data,int DataByte,int& OutByte);  
  20. };</span>  


ZBase64.cpp
[cpp] view plain copy
  1. #include "ZBase64.h"  
  2.   
  3. string ZBase64::Encode(const unsigned char* Data,int DataByte)  
  4. {  
  5.     //编码表  
  6.     const char EncodeTable[]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";  
  7.     //返回值  
  8.     string strEncode;  
  9.     unsigned char Tmp[4]={0};  
  10.     int LineLength=0;  
  11.     for(int i=0;i<(int)(DataByte / 3);i++)  
  12.     {  
  13.         Tmp[1] = *Data++;  
  14.         Tmp[2] = *Data++;  
  15.         Tmp[3] = *Data++;  
  16.         strEncode+= EncodeTable[Tmp[1] >> 2];  
  17.         strEncode+= EncodeTable[((Tmp[1] << 4) | (Tmp[2] >> 4)) & 0x3F];  
  18.         strEncode+= EncodeTable[((Tmp[2] << 2) | (Tmp[3] >> 6)) & 0x3F];  
  19.         strEncode+= EncodeTable[Tmp[3] & 0x3F];  
  20.         if(LineLength+=4,LineLength==76) {strEncode+="\r\n";LineLength=0;}  
  21.     }  
  22.     //对剩余数据进行编码  
  23.     int Mod=DataByte % 3;  
  24.     if(Mod==1)  
  25.     {  
  26.         Tmp[1] = *Data++;  
  27.         strEncode+= EncodeTable[(Tmp[1] & 0xFC) >> 2];  
  28.         strEncode+= EncodeTable[((Tmp[1] & 0x03) << 4)];  
  29.         strEncode+= "==";  
  30.     }  
  31.     else if(Mod==2)  
  32.     {  
  33.         Tmp[1] = *Data++;  
  34.         Tmp[2] = *Data++;  
  35.         strEncode+= EncodeTable[(Tmp[1] & 0xFC) >> 2];  
  36.         strEncode+= EncodeTable[((Tmp[1] & 0x03) << 4) | ((Tmp[2] & 0xF0) >> 4)];  
  37.         strEncode+= EncodeTable[((Tmp[2] & 0x0F) << 2)];  
  38.         strEncode+= "=";  
  39.     }  
  40.       
  41.     return strEncode;  
  42. }  
  43.   
  44. string ZBase64::Decode(const char* Data,int DataByte,int& OutByte)  
  45. {  
  46.     //解码表  
  47.     const char DecodeTable[] =  
  48.     {  
  49.         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,  
  50.         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,  
  51.         62, // '+'  
  52.         0, 0, 0,  
  53.         63, // '/'  
  54.         52, 53, 54, 55, 56, 57, 58, 59, 60, 61, // '0'-'9'  
  55.         0, 0, 0, 0, 0, 0, 0,  
  56.         0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,  
  57.         13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, // 'A'-'Z'  
  58.         0, 0, 0, 0, 0, 0,  
  59.         26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,  
  60.         39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, // 'a'-'z'  
  61.     };  
  62.     //返回值  
  63.     string strDecode;  
  64.     int nValue;  
  65.     int i= 0;  
  66.     while (i < DataByte)  
  67.     {  
  68.         if (*Data != '\r' && *Data!='\n')  
  69.         {  
  70.             nValue = DecodeTable[*Data++] << 18;  
  71.             nValue += DecodeTable[*Data++] << 12;  
  72.             strDecode+=(nValue & 0x00FF0000) >> 16;  
  73.             OutByte++;  
  74.             if (*Data != '=')  
  75.             {  
  76.                 nValue += DecodeTable[*Data++] << 6;  
  77.                 strDecode+=(nValue & 0x0000FF00) >> 8;  
  78.                 OutByte++;  
  79.                 if (*Data != '=')  
  80.                 {  
  81.                     nValue += DecodeTable[*Data++];  
  82.                     strDecode+=nValue & 0x000000FF;  
  83.                     OutByte++;  
  84.                 }  
  85.             }  
  86.             i += 4;  
  87.         }  
  88.         else// 回车换行,跳过  
  89.         {  
  90.             Data++;  
  91.             i++;  
  92.         }  
  93.      }  
  94.     return strDecode;  
  95. }  


3.使用示例(结合OpenCV)

main.cpp

[cpp] view plain copy
  1. <span style="font-size:18px;">#include<opencv2/opencv.hpp>  
  2. #include<iostream>  
  3. #include"ZBase64.h"  
  4. #include<vector>  
  5.   
  6.   
  7. using namespace std;  
  8. using namespace cv;  
  9.   
  10. void main()  
  11. {  
  12.     Mat img = imread("1.bmp");  
  13.   
  14.     vector<uchar> vecImg;                               //Mat 图片数据转换为vector<uchar>  
  15.     vector<int> vecCompression_params;  
  16.     vecCompression_params.push_back(CV_IMWRITE_JPEG_QUALITY);  
  17.     vecCompression_params.push_back(90);  
  18.     imencode(".jpg", img, vecImg, vecCompression_params);  
  19.   
  20.     ZBase64 base64;  
  21.     string imgbase64 = base64.Encode(vecImg.data(), vecImg.size());     //实现图片的base64编码  
  22.   
  23.     cout << imgbase64 << endl;  
  24. }</span>  

                       

    


参考文献

【1】http://www.cnblogs.com/chengxiaohui/articles/3951129.html

【2】http://www.ithao123.cn/content-18

【3】http://www.cppblog.com/wanghaiguang/archive/2013/03/20/198626.aspx

你可能感兴趣的:(C++实现图片的base64编码)