<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    探索者

    深挖
    posts - 1, comments - 1, trackbacks - 0, articles - 0

    Http chunked協(xié)議

    Posted on 2010-11-25 10:51 Bob.zhang 閱讀(7684) 評論(1)  編輯  收藏

    HTTP協(xié)議中的TRANFER-ENCODING:CHUNKED編碼解析
        通常情況下,Transfer-Encoding域的值應(yīng)當(dāng)為chunked,表明采用chunked編碼方式來進(jìn)行報文體的傳輸。chunked編碼是HTTP/1.1 RFC里定義的一種編碼方式,因此所有的HTTP/1.1應(yīng)用都應(yīng)當(dāng)支持此方式。
        chunked編碼的基本方法是將大塊數(shù)據(jù)分解成多塊小數(shù)據(jù),每塊都可以自指定長度,其具體格式如下(BNF文法):
        Chunked-Body   = *chunk            //0至多個chunk
                         last-chunk         //最后一個chunk
                         trailer            //尾部
                         CRLF               //結(jié)束標(biāo)記符

       chunk          = chunk-size [ chunk-extension ] CRLF  
                            chunk-data CRLF
       chunk-size     = 1*HEX
       last-chunk     = 1*("0") [ chunk-extension ] CRLF

       chunk-extension= *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
       chunk-ext-name = token
       chunk-ext-val  = token | quoted-string
       chunk-data     = chunk-size(OCTET)
       trailer        = *(entity-header CRLF)     
       
        解釋:
        Chunked-Body表示經(jīng)過chunked編碼后的報文體。報文體可以分為chunk, last-chunk,trailer和結(jié)束符四部分。chunk的數(shù)量在報文體中最少可以為0,無上限;每個chunk的長度是自指定的,即,起始的數(shù)據(jù)必然是16進(jìn)制數(shù)字的字符串,代表后面chunk-data的長度(字節(jié)數(shù))。這個16進(jìn)制的字符串第一個字符如果是“0”,則表示chunk-size為0,該chunk為last-chunk,無chunk-data部分??蛇x的chunk-extension由通信雙方自行確定,如果接收者不理解它的意義,可以忽略。
        trailer是附加的在尾部的額外頭域,通常包含一些元數(shù)據(jù)(metadata, meta means "about information"),這些頭域可以在解碼后附加在現(xiàn)有頭域之后。
        實例分析:
        下面分析用ethereal抓包使用Firefox與某網(wǎng)站通信的結(jié)果(從頭域結(jié)束符后開始):
    Address  0..........................  f
    000c0                                31
    000d0    66 66 63 0d 0a ...............   // ASCII碼:1ffc\r\n, chunk-data數(shù)據(jù)起始地址為000d5
             很明顯,“1ffc”為第一個chunk的chunk-size,轉(zhuǎn)換為int為8188.由于1ffc后馬上就是
             CRLF,因此沒有chunk-extension.chunk-data的起始地址為000d5, 計算可知下一塊chunk的起始
             地址為000d5+1ffc + 2=020d3,如下:
    020d0    .. 0d 0a 31 66 66 63 0d 0a .... // ASCII碼:\r\n1ffc\r\n
             前一個0d0a是上一個chunk的結(jié)束標(biāo)記符,后一個0d0a則是chunk-size和chunk-data的分隔符。
             此塊chunk的長度同樣為8188, 依次類推,直到最后一塊
    100e0                          0d 0a 31
    100f0    65 61 39 0d 0a......            //ASII碼:\r\n\1ea9\r\n
             此塊長度為0x1ea9 = 7849, 下一塊起始為100f5 + 1ea9 + 2 = 11fa0,如下:
    100a0    30 0d 0a 0d 0a                  //ASCII碼:0\r\n\r\n
             “0”說明當(dāng)前chunk為last-chunk, 第一個0d 0a為chunk結(jié)束符。第二個0d0a說明沒有trailer部分,整個Chunk-body結(jié)束。
        解碼流程:
        對chunked編碼進(jìn)行解碼的目的是將分塊的chunk-data整合恢復(fù)成一塊作為報文體,同時記錄此塊體的長度。
        RFC2616中附帶的解碼流程如下:(偽代碼)
        length := 0         //長度計數(shù)器置0
        read chunk-size, chunk-extension (if any) and CRLF      //讀取chunk-size, chunk-extension
                                                              //和CRLF
        while(chunk-size > 0 )   {            //表明不是last-chunk
              read chunk-data and CRLF            //讀chunk-size大小的chunk-data,skip CRLF
              append chunk-data to entity-body     //將此塊chunk-data追加到entity-body后
              read chunk-size and CRLF          //讀取新chunk的chunk-size 和 CRLF
        }
        read entity-header      //entity-header的格式為name:valueCRLF,如果為空即只有CRLF
        while (entity-header not empty)   //即,不是只有CRLF的空行
        {
           append entity-header to existing header fields
           read entity-header
        }
        Content-Length:=length      //將整個解碼流程結(jié)束后計算得到的新報文體length
                                     //作為Content-Length域的值寫入報文中
        Remove "chunked" from Transfer-Encoding  //同時從Transfer-Encoding中域值去除chunked這個標(biāo)記
        length最后的值實際為所有chunk的chunk-size之和,在上面的抓包實例中,一共有八塊chunk-size為0x1ffc(8188)的chunk,剩下一塊為0x1ea9(7849),加起來一共73353字節(jié)。
        注:對于上面例子中前幾個chunk的大小都是8188,可能是因為:"1ffc" 4字節(jié),"\r\n"2字節(jié),加上塊尾一個"\r\n"2字節(jié)一共8字節(jié),因此一個chunk整體為8196,正好可能是發(fā)送端一次TCP發(fā)送的緩存大小。

    Feedback

    # re: Http chunked協(xié)議  回復(fù)  更多評論   

    2012-12-04 14:09 by 測試
    測試

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 亚洲另类无码专区首页| 久久夜色精品国产噜噜亚洲AV| 婷婷亚洲天堂影院| 国产成人亚洲综合色影视| 激情五月亚洲色图| 99久久99这里只有免费的精品| 99久久免费国产精品特黄| 精品亚洲视频在线观看| 亚洲人成小说网站色| 免费无码作爱视频| 国产在线观看免费完整版中文版 | 亚洲精品在线视频| 亚洲人成www在线播放| 久久99九九国产免费看小说| 国产亚洲人成无码网在线观看| 亚洲精品天堂无码中文字幕| 污视频在线观看免费| 国产亚洲精品精品国产亚洲综合| 阿v免费在线观看| 国产桃色在线成免费视频| 亚洲精品精华液一区二区| 免费黄色毛片视频| 久久久无码精品亚洲日韩按摩 | 边摸边吃奶边做爽免费视频99| 亚洲AⅤ优女AV综合久久久| 一级毛片人与动免费观看| 天天操夜夜操免费视频| 亚洲毛片在线免费观看| 182tv免费视频在线观看| 久久精品国产亚洲AV嫖农村妇女| 亚洲免费闲人蜜桃| 亚洲精品成人久久| 午夜免费福利在线观看| 国产精品福利片免费看| 亚洲视频人成在线播放| 日本高清免费中文在线看| 国产精品免费视频网站| 久久免费视频一区| 免费成人av电影| 青娱乐在线视频免费观看| 久久精品国产99精品国产亚洲性色|