HTTP Response中的Chunked编码
進行Chunked編碼傳輸的HTTP Response會在消息頭部設置:
Transfer-Encoding: chunked
表示Content Body將用Chunked編碼傳輸內容。
Chunked編碼使用若干個Chunk串連而成,由一個標明長度為0的chunk標示結束。每個Chunk分為頭部和正文兩部分,頭部內容指定下一段正文的字符總數(十六進制的數字)和數量單位(一般不寫),正文部分就是指定長度的實際內容,兩部分之間用回車換行(CRLF)隔開。在最后一個長度為0的Chunk中的內容是稱為footer的內容,是一些附加的Header信息(通常可以直接忽略)。具體的Chunk編碼格式如下:
  Chunked-Body = *chunk
 "0" CRLF
 footer
 CRLF 
 chunk = chunk-size [ chunk-ext ] CRLF
 chunk-data CRLF
hex-no-zero = <HEX excluding "0">
  chunk-size = hex-no-zero *HEX
 chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-value ] )
 chunk-ext-name = token
 chunk-ext-val = token | quoted-string
 chunk-data = chunk-size(OCTET)
footer = *entity-header
RFC文檔中的Chunked解碼過程如下:
 length := 0
 read chunk-size, chunk-ext (if any) and CRLF
 while (chunk-size > 0) {
 read chunk-data and CRLF
 append chunk-data to entity-body
 length := length + chunk-size
 read chunk-size and CRLF
 }
 read entity-header
 while (entity-header not empty) {
 append entity-header to existing header fields
 read entity-header
 }
 Content-Length := length
 Remove "chunked" from Transfer-Encoding
最后提供一段PHP版本的chunked解碼代碼:
$chunk_size  = (integer)hexdec(fgets( $socket_fd, 4096 ) );
 while(!feof($socket_fd) && $chunk_size > 0) {
 ????$bodyContent  .= fread( $socket_fd, $chunk_size );
 ????fread( $socket_fd, 2 );  // skip \r\n
 ??? $chunk_size  = (integer)hexdec(fgets( $socket_fd, 4096 ) );
 }
總結
以上是生活随笔為你收集整理的HTTP Response中的Chunked编码的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 动作导演主要负责拍摄动作戏吗
 - 下一篇: ASP.NET弹出窗口技术之增加网站流量