• <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 王海光 閱讀(11352) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            久久99精品久久久久久9蜜桃| 久久久久久亚洲AV无码专区| 日本高清无卡码一区二区久久| 久久综合给合综合久久| 中文字幕久久精品无码| 国产精品久久久久…| 欧美与黑人午夜性猛交久久久 | 久久性精品| 亚洲va久久久噜噜噜久久天堂| 99麻豆久久久国产精品免费| 久久精品国产精品亚洲艾草网美妙| 久久精品国产免费观看 | 国产免费久久精品99re丫y| 97久久久精品综合88久久| 日韩美女18网站久久精品| 丰满少妇人妻久久久久久| 国产精品中文久久久久久久| 亚洲国产精品久久久久网站| 亚洲精品国产字幕久久不卡| 麻豆国内精品久久久久久| 伊人久久综合热线大杳蕉下载| 久久人做人爽一区二区三区| 久久久久99精品成人片三人毛片| 精品久久久久久无码专区不卡| 丁香色欲久久久久久综合网| 久久影视综合亚洲| 久久精品国产WWW456C0M| 久久精品国产秦先生| 久久久久国产精品熟女影院| 波多野结衣AV无码久久一区| 欧美日韩精品久久久免费观看| 亚洲一本综合久久| 国产成人久久久精品二区三区| 国产精品欧美久久久天天影视| 久久AV高清无码| 97久久香蕉国产线看观看| 久久这里只有精品18| 亚洲综合熟女久久久30p| 久久偷看各类wc女厕嘘嘘| 日本人妻丰满熟妇久久久久久| 久久久久亚洲AV片无码下载蜜桃 |