博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTTP chunked【转】
阅读量:2186 次
发布时间:2019-05-02

本文共 868 字,大约阅读时间需要 2 分钟。

(转自:)

持久连接

HTTP1.1中引入了持久连接,使用以下Header,则TCP连接可以不会被关闭,可以被多个请求重用。

Connection: keep-alive

Content-Length

在使用持久连接的前提下,当客户端向服务器发送请求A和请求B,服务器会按序回复响应A和响应B,为了知道响应A的数据接收完毕,开始接收响应B的数据,我们需要使用Content-Length来声明数据的大小。

Content-Length: 1024

当客户端读取了第一行数据(响应行),读取若干行数据(响应头)直至读到\r\n为止,接下来根据Content-Length读取数据,当读完Content-Length个字节时,当前响应读取完毕,可以开始下一个响应。

分块传输-chunked

当返回的数据比较大时,如果等待生成完数据再传输,这样效率比较低下。相比而言,服务器更希望边生成数据边传输。可以在响应头加上以下字段标识分块传输:

Transfer-Encoding: chunked

(1)当选择分块传输时,响应头中可以不包含Content-Length。

(2)服务器会先回复一个不带数据的报文(只有响应行和响应头和\r\n),然后开始传输若干个数据块。 

每个数据块格式如下:

400                      -------------------->该块数据的大小,16进制,这里表示1024Bytes

adfaddaffasd...          -------------------->数据
                         -------------------->换行

(3)当传输完若干个数据块后,需要再传输一个空的数据块

30                      -------------------->数据块大小为0

                        -------------------->大小为0时也需要一个换行\r\n
                        -------------------->换行

(4) 当客户端收到空的数据块时,则客户端知道数据接收完毕。

可用于测试chunked的url

chunked报文例子

  • 先发送一个没有数据的响应 

这里写图片描述

  • 若干个数据块

这里写图片描述

  • 最后一个空数据块 

这里写图片描述

你可能感兴趣的文章
【LEETCODE】278-First Bad Version
查看>>
【LEETCODE】303-Range Sum Query - Immutable
查看>>
【LEETCODE】21-Merge Two Sorted Lists
查看>>
【LEETCODE】231-Power of Two
查看>>
【LEETCODE】172-Factorial Trailing Zeroes
查看>>
【LEETCODE】112-Path Sum
查看>>
【LEETCODE】9-Palindrome Number
查看>>
【极客学院】-python学习笔记-Python快速入门(面向对象-引入外部文件-Web2Py创建网站)
查看>>
【LEETCODE】190-Reverse Bits
查看>>
【LEETCODE】67-Add Binary
查看>>
【LEETCODE】7-Reverse Integer
查看>>
【LEETCODE】165-Compare Version Numbers
查看>>
【LEETCODE】299-Bulls and Cows
查看>>
【LEETCODE】223-Rectangle Area
查看>>
【LEETCODE】12-Integer to Roman
查看>>
【学习方法】如何分析源代码
查看>>
【LEETCODE】61- Rotate List [Python]
查看>>
【LEETCODE】143- Reorder List [Python]
查看>>
【LEETCODE】82- Remove Duplicates from Sorted List II [Python]
查看>>
【LEETCODE】86- Partition List [Python]
查看>>