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

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            理解HTTP協議中的"Transfer-Encoding: chunked"

            通常,HTTP協議中使用Content-Length這個頭來告知數據的長度。然后,在數據下行的過程中,Content-Length的方式要預先在服務器中緩存所有數據,然后所有數據再一股腦兒地發給客戶端。
               
            如果要一邊產生數據,一邊發給客戶端,WEB 服務器就需要使用"Transfer-Encoding: chunked"這樣的方式來代替Content-Length

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

            \r\n
            \r\n      --
            連續的兩個\r\n之后就是HTTP體了
            16
            進制值代表的數據長度
            \r\n
            上面所指的數據長度
            \r\n    --
            每段數據結束后,以\r\n標識

            16
            進制代表的第二段數據
            \r\n
            XX
            長度的數據
            \r\n

            ………… (
            反復通過這樣的方式表示每次傳輸的數據長度)

            0      --
            數據結束部分用0表示,然后是連續的兩個\r\n
            \r\n
            \r\n

                 
            下面的代碼演示和如何解析"Transfer-Encoding: chunked"的數據:
            //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("
            格式錯誤!\n");
                        break;
                    }
                    nLen = pTemp-pStart;
                    COPY_STRING(temp, pStart, nLen);
                    nBytes = Hex2Int(temp);
                    pStart = pTemp + 2;
                    //
            下面寫入到另一個文件
                    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 肥仔 閱讀(7155) 評論(0)  編輯 收藏 引用 所屬分類: Web-后臺

            久久无码AV中文出轨人妻| 国产精品久久久99| 国产69精品久久久久9999APGF| 亚洲精品第一综合99久久| 亚洲精品午夜国产va久久| 97久久香蕉国产线看观看| 国内精品久久久久久麻豆| 99精品久久精品一区二区| 2022年国产精品久久久久| 久久无码人妻精品一区二区三区 | 欧美久久综合九色综合| 国产激情久久久久久熟女老人 | 久久综合九色综合精品| 国内精品伊人久久久影院| 国产韩国精品一区二区三区久久| 久久99精品久久久久久水蜜桃| 精品熟女少妇AV免费久久| 精品人妻伦九区久久AAA片69| 久久综合噜噜激激的五月天| 久久精品18| 99久久精品国产综合一区| 东方aⅴ免费观看久久av| 天天综合久久一二三区| 亚洲国产精品久久久久| 久久99国产综合精品免费| 亚洲伊人久久大香线蕉综合图片| 欧美午夜A∨大片久久| 国产精久久一区二区三区 | 精品国产综合区久久久久久| 久久偷看各类wc女厕嘘嘘| 午夜精品久久久久久久| 国产69精品久久久久观看软件 | 国产欧美久久久精品| 久久亚洲精品人成综合网| 亚洲国产精品无码久久青草 | 亚洲精品乱码久久久久久中文字幕 | 亚洲精品tv久久久久| 久久精品国产99久久香蕉| 久久精品国产亚洲Aⅴ蜜臀色欲| 91精品国产91热久久久久福利 | 97精品久久天干天天天按摩|