• <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水蜜桃| 人人狠狠综合久久亚洲婷婷| 国产精品成人99久久久久| 国产精品对白刺激久久久| 新狼窝色AV性久久久久久| 狠狠色丁香久久婷婷综合| 国产精品中文久久久久久久| 久久久无码精品亚洲日韩蜜臀浪潮| 久久久久久久免费视频| 久久精品中文字幕一区| 久久久av波多野一区二区| 国内精品九九久久久精品| 久久最近最新中文字幕大全 | 亚洲人成网亚洲欧洲无码久久| 久久久这里有精品| 色诱久久久久综合网ywww | 无码精品久久久天天影视| 久久久久99精品成人片试看| 久久久精品免费国产四虎| 99久久精品国产一区二区三区| 久久久噜噜噜久久| 欧美一区二区三区久久综| 久久香蕉国产线看观看乱码| 欧美午夜A∨大片久久 | 久久精品中文闷骚内射| 国产成人久久精品麻豆一区| 青青久久精品国产免费看| 日本久久久久亚洲中字幕| 久久久精品视频免费观看| 久久久久亚洲av成人网人人软件 | 久久人妻少妇嫩草AV无码专区| 久久精品视频网| 一本久久a久久精品vr综合| 久久综合九色综合精品| 性色欲网站人妻丰满中文久久不卡| 麻豆精品久久精品色综合| 久久久久久综合网天天| 久久成人18免费网站| 2021久久精品国产99国产精品| 久久经典免费视频| 免费一级欧美大片久久网|