base64编解码

来源:互联网 发布:lsd可以在淘宝上买到 编辑:程序博客网 时间:2024/05/22 05:05
  1. 此文主要是运用总结,无技术创新,在一次的项目中需要通过webservice接收图像文件信息,webservice接口返回给我的是base64字符串。所谓Base64,就是说选出64个字符----小写字母a-z、大写字母A-Z、数字0-9、符号"+"、"/"(再加上作为垫字的"=",实际上是65个字符)----作为一个基本字符集。编码的过程大致为首先取出3个字节,共24位,分为4组,每组6位,将每组的前两位补0,再扩展成为32位的数字,查找对应的标准表即代表对应的字符值。这相当于是编码的一个描述,当时我在运用时并不需要我进行编码的一个操作,只需要做相应的解码即可。于是乎按照编码的逆序写了一个解码的函数,结果没有得到我所预期。查找相关资料发现,一般情况下internet中使用base64有一定的要求,要求每行不超过76个字符,否则填充回车换行符。
  2. 编码的函数如下:
static const std::string base64_chars = 
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789+/";
 std::string base64_encode(unsigned char const* bytes_to_encode, unsigned int in_len) {
std::string ret;
int i = 0;
int j = 0;
unsigned char char_array_3[3];
unsigned char char_array_4[4];
while (in_len--) {
char_array_3[i++] = *(bytes_to_encode++);
if (i == 3) {
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++)
ret += base64_chars[char_array_4[i]];
i = 0;
}
}
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++)
ret += base64_chars[char_array_4[j]];
while((i++ < 3))
ret += '=';
}
return ret;

}

3.解码的函数如下:

std::string base64_decode(const char* src,int srcLength,int& dstLength)
{
//解码表
const char DecodeTable[] =
{
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
62, // '+'
0, 0, 0,
63, // '/'
52, 53, 54, 55, 56, 57, 58, 59, 60, 61, // '0'-'9'
0, 0, 0, 0, 0, 0, 0,
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, // 'A'-'Z'
0, 0, 0, 0, 0, 0,
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, // 'a'-'z'
};
//返回值
std::string dstStr;
int nValue;
int i= 0;
while (i < srcLength)
{
if (*Data != '\r' && *src!='\n')
{
nValue = DecodeTable[*src++] << 18;
nValue += DecodeTable[*src++] << 12;
dstStr+=(nValue & 0x00FF0000) >> 16;
dstLength++;
if (*src != '=')
{
nValue += DecodeTable[*src++] << 6;
dstStr+=(nValue & 0x0000FF00) >> 8;
dstLength++;
if (*src != '=')
{
nValue += DecodeTable[*src++];
dstStr+=nValue & 0x000000FF;
dstLength++;
}
}
i += 4;
}
else// 回车换行,跳过
{
src++;
i++;
}
}
return dstStr;
}

0 0
原创粉丝点击