您的位置:首页 > 编程语言 > C语言/C++

C++ base64 编解码

2015-07-23 16:31 405 查看
/**

* @brief C++ base64 编解码

* @author wid

* @date 2013-20-25

*

* @note 若代码存在 bug 或程序缺陷, 请留言反馈, 谢谢!

*/

#include <iostream>

#include <string>

#include <ctime>

string Decode(const char* Data,int DataByte,int& OutByte);

string Encode(const unsigned char* Data,int DataByte);

string Encode(const unsigned char* Data,int DataByte)

{

    //编码表

    const char EncodeTable[]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";

    //返回值

    string strEncode;

    unsigned char Tmp[4]={0};

    int LineLength=0;

    for(int i=0;i<(int)(DataByte / 3);i++)

    {

        Tmp[1] = *Data++;

        Tmp[2] = *Data++;

        Tmp[3] = *Data++;

        strEncode+= EncodeTable[Tmp[1] >> 2];

        strEncode+= EncodeTable[((Tmp[1] << 4) | (Tmp[2] >> 4)) & 0x3F];

        strEncode+= EncodeTable[((Tmp[2] << 2) | (Tmp[3] >> 6)) & 0x3F];

        strEncode+= EncodeTable[Tmp[3] & 0x3F];

        if(LineLength+=4,LineLength==76) {strEncode+="\r\n";LineLength=0;}

    }

    //对剩余数据进行编码

    int Mod=DataByte % 3;

    if(Mod==1)

    {

        Tmp[1] = *Data++;

        strEncode+= EncodeTable[(Tmp[1] & 0xFC) >> 2];

        strEncode+= EncodeTable[((Tmp[1] & 0x03) << 4)];

        strEncode+= "==";

    }

    else if(Mod==2)

    {

        Tmp[1] = *Data++;

        Tmp[2] = *Data++;

        strEncode+= EncodeTable[(Tmp[1] & 0xFC) >> 2];

        strEncode+= EncodeTable[((Tmp[1] & 0x03) << 4) | ((Tmp[2] & 0xF0) >> 4)];

        strEncode+= EncodeTable[((Tmp[2] & 0x0F) << 2)];

        strEncode+= "=";

    }

    

    return strEncode;

}

/**

* @brief 对 base64 编码后的字符串进行解码

*

* @param strString 待解码的字符串

*

* @return std::string 返回解码后的字符串

*

* @note 对于非base64编码的字符串或已损坏的base64字符串进行解码会抛出 std::string 型异常, 请捕获

*/

string Decode(const char* Data,int DataByte,int& OutByte)

{

    //解码表

    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'

    };

    //返回值

    string strDecode;

    int nValue;

    int i= 0;

    while (i < DataByte)

    {

        if (*Data != '\r' && *Data!='\n')

        {

            nValue = DecodeTable[*Data++] << 18;

            nValue += DecodeTable[*Data++] << 12;

            strDecode+=(nValue & 0x00FF0000) >> 16;

            OutByte++;

            if (*Data != '=')

            {

                nValue += DecodeTable[*Data++] << 6;

                strDecode+=(nValue & 0x0000FF00) >> 8;

                OutByte++;

                if (*Data != '=')

                {

                    nValue += DecodeTable[*Data++];

                    strDecode+=nValue & 0x000000FF;

                    OutByte++;

                }

            }

            i += 4;

        }

        else// 回车换行,跳过

        {

            Data++;

            i++;

        }

     }

    return strDecode;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: