取消掉Transfer-Encoding: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-da
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-da
footer = *entity-header
RFC文檔中的Chunked解碼過程如下:
length := 0
read chunk-size, chunk-ext (if any) and CRLF
while (chunk-size > 0) {
read chunk-da
append chunk-da
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?) );
}
要解決服務器不返回Transfer-Encoding:chunked,在客戶端請求的時候可以使用http 1.0的協議。
總結
以上是生活随笔為你收集整理的取消掉Transfer-Encoding:chunked的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微信网名女生温柔的
- 下一篇: 郑州考驾校到底多少钱?