• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            面對現實,超越自己
            逆水行舟,不進則退
            posts - 269,comments - 32,trackbacks - 0
            .h文件:
            #include <string>
            using namespace std;

            class ZBase64
            {
            public:
                /*編碼
                DataByte
                    [in]輸入的數據長度,以字節為單位
                
            */
                string Encode(const unsigned char* Data,int DataByte);
                /*解碼
                DataByte
                    [in]輸入的數據長度,以字節為單位
                OutByte
                    [out]輸出的數據長度,以字節為單位,請不要通過返回值計算
                    輸出數據的長度
                
            */
                string Decode(const char* Data,int DataByte,int& OutByte);
            };

            .cpp文件:
            #include "stdAfx.h"
            #include "ZBase64.h"

            string ZBase64::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;
            }

            string ZBase64::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,
            // '/'
            , 53, 54, 55, 56, 57, 58, 59, 60, 61, // '0'-'9'
            , 0, 0, 0, 0, 0, 0,
            , 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,
            , 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, // 'A'-'Z'
            , 0, 0, 0, 0, 0,
            , 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,
            , 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;
            }

            使用示例(結合CxImage庫):
            CString CScanDlg::EncodeImage()
            {//對圖片進行Base64編碼
                ZBase64 zBase;
                //圖片編碼
                CxImage  image;   // 定義一個CxImage對象    
                image.Load(this->m_strImgPath, CXIMAGE_FORMAT_JPG);   //先裝載jpg文件,需要指定文件類型
                long size=0;//得到圖像大小
                BYTE* buffer=0;//存儲圖像數據的緩沖
                image.Encode(buffer,size,CXIMAGE_FORMAT_JPG);//把image對象中的圖像以type類型數據copy到buffer
                string strTmpResult=zBase.Encode(buffer,size);
                CString result;
                result = strTmpResult.c_str();
                return result;
            }

            void CScanDlg::DecodeImageData(CString strData)
            {//對Base64編碼過的數據解碼并顯示原圖片

                ZBase64 zBase;
                int OutByte=0;
                string strTmpResult=zBase.Decode(strData,strData.GetLength(),OutByte);
                int i,len = strTmpResult.length();
                BYTE *buffer = new BYTE[len];
                for (i=0;i<len;++i)
                {
                    buffer[i] = strTmpResult[i];
                }
                CxImage image(buffer,len,CXIMAGE_FORMAT_JPG);//把內存緩沖buffer中的數據構造成Image對象
                delete [] buffer;
                CDC* hdc = m_picture.GetDC();
                m_bitmap = image.MakeBitmap(hdc->m_hDC);
                HBITMAP h0ldBmp = m_picture.SetBitmap(m_bitmap);
                if(h0ldBmp) DeleteObject(h0ldBmp);
                if(hdc->m_hDC) m_picture.ReleaseDC(hdc);
                if(m_bitmap) DeleteObject(m_bitmap);
            }

            本文轉自:http://www.cnblogs.com/phinecos/archive/2008/10/10/1308272.html
            posted on 2013-03-20 14:00 王海光 閱讀(11332) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            伊人久久一区二区三区无码| 久久久久久久97| 久久久精品国产亚洲成人满18免费网站 | 一本久久a久久精品亚洲| 国内精品久久久久影院日本| 精品午夜久久福利大片| 欧美大战日韩91综合一区婷婷久久青草| 无码任你躁久久久久久老妇| 久久亚洲精品人成综合网| 伊人久久精品线影院| 青青草国产97免久久费观看| 国产精品福利一区二区久久| 久久99精品久久久久久噜噜| 欧洲精品久久久av无码电影| 久久久噜噜噜久久| 99精品久久久久久久婷婷| 久久亚洲精品成人av无码网站| 久久国产影院| 青青国产成人久久91网| 亚洲精品无码久久久久去q | 久久成人永久免费播放| 九九精品99久久久香蕉| 久久婷婷五月综合97色直播| 国产精品热久久毛片| 久久精品国产亚洲欧美| 99精品久久精品一区二区| 亚洲精品无码成人片久久| 久久亚洲精品无码VA大香大香| 国产精品99久久久久久猫咪| 国产成人精品久久二区二区| 日韩精品久久久久久免费| 精品无码久久久久国产动漫3d| 伊人久久亚洲综合影院| 久久久亚洲裙底偷窥综合| 久久综合伊人77777麻豆| 人妻丰满?V无码久久不卡| 久久久久久国产a免费观看不卡| 国产精久久一区二区三区| 国内精品久久久久影院网站| 伊人色综合久久| 久久综合九色综合欧美就去吻|