• <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 肥仔 閱讀(7156) 評論(0)  編輯 收藏 引用 所屬分類: Web-后臺

            亚洲国产另类久久久精品黑人 | 少妇内射兰兰久久| 久久久久亚洲AV无码观看| 亚洲∧v久久久无码精品| 2021精品国产综合久久| 国产精品久久久天天影视香蕉| 香蕉久久永久视频| 久久精品国产亚洲精品2020| 久久精品国产精品亚洲| 亚洲综合精品香蕉久久网| 久久美女人爽女人爽| 波多野结衣AV无码久久一区| 精品久久久久久久久久久久久久久| 久久精品国产欧美日韩99热| av无码久久久久久不卡网站 | 波多野结衣久久| 97精品久久天干天天天按摩| 一级做a爰片久久毛片免费陪| 国产精品久久久福利| 国产偷久久久精品专区| 91精品国产91久久| 77777亚洲午夜久久多喷| 丁香色欲久久久久久综合网| 欧美国产成人久久精品| 国内精品久久久久久久久| 久久99久久99小草精品免视看| 欧美伊人久久大香线蕉综合| 久久综合色之久久综合| 99久久精品免费国产大片| 狠狠色丁香婷婷久久综合不卡| 久久精品国产99久久无毒不卡| 亚洲人成无码久久电影网站| 久久精品国产一区二区三区| 久久精品无码一区二区app| 久久91精品国产91久久麻豆| 国产午夜精品理论片久久影视| 久久国产色AV免费观看| 97久久精品人妻人人搡人人玩| 狠色狠色狠狠色综合久久| 精品国产福利久久久| 99精品伊人久久久大香线蕉|