• <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>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            理解HTTP協(xié)議中的"Transfer-Encoding: chunked"

            通常,HTTP協(xié)議中使用Content-Length這個(gè)頭來(lái)告知數(shù)據(jù)的長(zhǎng)度。然后,在數(shù)據(jù)下行的過(guò)程中,Content-Length的方式要預(yù)先在服務(wù)器中緩存所有數(shù)據(jù),然后所有數(shù)據(jù)再一股腦兒地發(fā)給客戶端。
               
            如果要一邊產(chǎn)生數(shù)據(jù),一邊發(fā)給客戶端,WEB 服務(wù)器就需要使用"Transfer-Encoding: chunked"這樣的方式來(lái)代替Content-Length

                "Transfer-Encoding: chunked"
            是這樣編碼的:
            HTTP

            \r\n
            \r\n      --
            連續(xù)的兩個(gè)\r\n之后就是HTTP體了
            16
            進(jìn)制值代表的數(shù)據(jù)長(zhǎng)度
            \r\n
            上面所指的數(shù)據(jù)長(zhǎng)度
            \r\n    --
            每段數(shù)據(jù)結(jié)束后,以\r\n標(biāo)識(shí)

            16
            進(jìn)制代表的第二段數(shù)據(jù)
            \r\n
            XX
            長(zhǎng)度的數(shù)據(jù)
            \r\n

            ………… (
            反復(fù)通過(guò)這樣的方式表示每次傳輸?shù)臄?shù)據(jù)長(zhǎng)度)

            0      --
            數(shù)據(jù)結(jié)束部分用0表示,然后是連續(xù)的兩個(gè)\r\n
            \r\n
            \r\n

                 
            下面的代碼演示和如何解析"Transfer-Encoding: chunked"的數(shù)據(jù):
            //test_chunked.cpp
            #include <stdio.h>
            #include <string.h>

            int Hex2Int(const char* str)
            {
                int nResult = 0;
                while (*str!='\0')
                {
                    switch (*str)
                    {
                    case '0'...'9':
                        nResult = nResult*16 + *str-'0';
                        break;
                    case 'a'...'f':
                        nResult = nResult*16 + *str-'a'+10;
                        break;
                    case 'A'...'F':
                        nResult = nResult*16 + *str-'A'+10;
                        break;
                    default:
                        return -1;
                        break;
                    }
                    str++;
                }
                return nResult;
            }

            #define COPY_STRING(dst, src, src_len) do{memcpy((dst), (src), (src_len)); dst[(src_len)]='\0';}while(0);

            void test(const char* file)
            {
                //
                const int BUFFER_SIZE = 1024*10;
                char* buf = new char[BUFFER_SIZE];
                FILE* fp = fopen(file, "rb");
                if (NULL==fp)
                {
                    printf("open file error\n");
                    return;
                }
                int nLen = fread(buf, 1, BUFFER_SIZE, fp);
                fclose(fp);
                fp = NULL;
                buf[nLen] = '\0';
                //
                char* pBody = strstr(buf, "\r\n\r\n");
                if (NULL==pBody)
                {
                    return;
                }
                pBody += 4;
                FILE* fDst = fopen("result.txt.gz", "ab");
                //
            下面開始解析
                int nBytes;
                char* pStart = pBody;
                char* pTemp;
                char temp[10];
                do
                {
                    pTemp = strchr(pStart, '\r');
                    if (NULL==pTemp)
                    {
                        printf("
            格式錯(cuò)誤!\n");
                        break;
                    }
                    nLen = pTemp-pStart;
                    COPY_STRING(temp, pStart, nLen);
                    nBytes = Hex2Int(temp);
                    pStart = pTemp + 2;
                    //
            下面寫入到另一個(gè)文件
                    if (nBytes>0)
                    {
                        if (nBytes!=fwrite(pStart, 1, nBytes, fDst))
                        {
                            printf("write error!\n");
                            break;
                        }
                        pStart += nBytes + 2;
                    }
                } while(nBytes>0);
                fclose(fDst);
                fDst = NULL;
                delete[] buf;
                buf = NULL;
            }

            int main()
            {
                test("chunked.txt");
                return 1;
            }

             

            posted on 2011-06-26 03:09 肥仔 閱讀(7169) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Web-后臺(tái)

            精品久久无码中文字幕| 亚洲AV日韩精品久久久久久| 精品久久香蕉国产线看观看亚洲| 久久人妻少妇嫩草AV无码专区| 国内精品人妻无码久久久影院| 伊人色综合久久| 久久久精品人妻一区二区三区蜜桃| 国产精品岛国久久久久| 亚洲人成无码久久电影网站| 久久午夜无码鲁丝片| 久久久久国产| AV无码久久久久不卡蜜桃| 久久这里只有精品视频99| 久久精品嫩草影院| 青草国产精品久久久久久| 久久国产成人午夜aⅴ影院 | 国产成人久久777777| 性欧美大战久久久久久久久 | 岛国搬运www久久| 久久99精品久久久久久久不卡 | 久久精品无码专区免费青青| 久久亚洲AV无码西西人体| 久久99毛片免费观看不卡| 久久综合给合久久国产免费| 久久久久青草线蕉综合超碰| 欧美激情精品久久久久久久九九九 | 亚洲国产成人久久综合碰碰动漫3d| 亚洲精品无码久久不卡| 久久精品综合一区二区三区| 午夜不卡888久久| 久久综合狠狠综合久久激情 | 久久99精品久久久久久hb无码| 综合人妻久久一区二区精品| 亚洲伊人久久大香线蕉综合图片| 国内精品久久久久影院亚洲| 亚洲精品NV久久久久久久久久 | 三上悠亚久久精品| 精品熟女少妇av免费久久| 精品综合久久久久久888蜜芽| 久久91精品国产91久久户| 91精品国产91久久|