Transfer-Encoding: chunked 的含义
在用firebug查看服务器的请求时,返回的header都有Transfer-Encoding: chunked,在做实际应用时,好像也
没有多大关系。
试试用socket连接http服务器,看看数据是如何传输的。
Socket s = new Socket("172.16.1.123", 80);
InputStream ins = s.getInputStream();
OutputStream os = s.getOutputStream();
os.write("GET /a.jsp HTTP/1.1\r\n".getBytes());
os.write("Host:172.16.1.123\r\n".getBytes());
//必须加host,否则服务器会返回bad request,无论是tomcat还是resin,还是nginx或者apache httpd
os.write("\r\n\r\n".getBytes());//这个也必不可少,http协议规定的
os.flush();
BufferedReader br = new BufferedReader(new InputStreamReader(ins));
String line = null;
line = br.readLine();
while(line != null){
System.out.println(line);
line = br.readLine();
}
ins.close();
用tomcat做服务器,建立一个a.jsp文件
<% out.print("helloworld!");
out.flush();
out.print("123");
out.flush();
%>
输出结果是:
引用
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Set-Cookie: JSESSIONID=8A7461DDA53B4C4DD0E89D73219CB5F8; Path=/
Content-Type: text/html;charset=UTF-8
Transfer-Encoding: chunked
Date: Wed, 10 Nov 2010 07:10:05 GMT
b
helloworld!
3
123
0
其中Transfer-Encoding:chunked表示内容长度在后面介绍,b这个16进制数字就表示长度为11,然后是内容
(helloworld!),然后以\r\n结束,如果有下一段,则一个16进制数字表示长度,直到最后一段没有了,才以0
结束。
不过不用担心,在浏览器里会自动解释分析,不会让你看到b,3,0,就算在firebug里也显示的是helloworld!
123。
如果自己解析,就需要注意了。
分享到:
相关推荐
3. 异步读取响应头,检查“Transfer-Encoding”字段确认是否使用了chunked编码。 4. 如果使用了chunked编码,开始异步读取每个chunk: - 读取十六进制的chunk大小。 - 读取chunk数据,直到达到指定的字节数。 - ...
1. **读取头部信息**:首先,你需要解析HTTP响应头,寻找`Transfer-Encoding: chunked`字段,这表明后续的数据将以chunked编码的形式传输。同时,也要注意`Content-Type`头,因为它定义了数据的类型。 2. **理解...
Chunked-Body = *chunk last-chunk trailer CRLF。Chunked格式的数据传输过程是将数据切割成一系列的块数据传输,每个块数据的长度由Chunk-Size指定,然后紧接着是该块数据的内容,以CRLF标志结束。最后以“0”CRLF...
Transfer-Encoding:chunked Location:http://localhost:5000/api/companies/61156544-d8bd-4787-a79a-a484dd9a382c 在浏览器中输入http://localhost:5000/api/companies/61156544-d8bd-4787-a79a-a484dd9a382c ...
- **实现方式**: 服务器可通过设置`Transfer-Encoding: chunked`响应头来启用分块传输。客户端接收到数据后,根据十六进制的长度标识解析数据块。 ##### 3.2 数据压缩 - **支持情况**: 常见的压缩算法如gzip、...
在HTTP协议中,`Transfer-Encoding: chunked`是一种用于分块传输编码的方式,常用于服务器无法预先知道响应体总长度的情况。这种方式将响应体分成多个块(chunks),每一块都有一个大小标识,最后以一个零长度的块...
Spring MVC + MessagePack 示例 跑步 $ mvn spring-boot:run $ curl -v "localhost:8080/calc?... Transfer-Encoding: chunked < Date: Fri, 16 Jan 2015 15:00:26 GMT < leftd right , answer
无服务器测试示例 该存储库说明了一些测试使用构建的应用程序的策略。 我已经在“媒介:上发表了有关此的文章 设置 安装Node 8.10(AWS Lambda支持的最新运行时)...Transfer-Encoding: chunked access-control-allow
解决方法一:关闭 Transfer-encoding: chunked WebLogic 服务器提供了一个配置选项,用于关闭 chunked 编码的传输方式。这可以通过 WLST(WebLogic Scripting Tool)工具来实现。具体步骤如下: 1. 启动 WLST 工具...
15. Transfer-Encoding: 响应传输的编码方式,如chunked。 16. Vary: 告诉缓存服务器如何根据请求头选择缓存资源。 17. WWW-Authenticate: 身份验证的挑战信息,用于401 Unauthorized响应。 以上是HTTP请求和响应头...
5. 在Burp Suite的历史记录中找到相关的请求,检查是否包含`Transfer-Encoding: chunked`的头部。如果有,说明chunked编码已成功应用。 6. 分析响应,确认WAF是否被成功绕过。 参考项目主页和相关文章,可以深入...
- 长连接:使用`Transfer-Encoding: chunked`,适合大文件传输。 - Web框架支持:Flask/Django等提供设置响应头和返回文件流的方法。 4. 所用的包: - Flask-Uploads/WTForms-FileField:Flask中的文件上传处理...
6. Transfer-Encoding:用于指定实体部分的编码方式,目前只能支持 chunked。 7. Upgrade:用于指定客户端支持的通信协议,例如 HTTP/2.0 和 SHTTP/1.3。 8. Via:用于指定代理服务器的名称和协议。 二、请求头 ...
在这种情况下,数据被分割成多个块,并通过`Transfer-Encoding: chunked`头字段告知客户端,数据将以块的形式传输。 分块传输编码的工作原理是,每个数据块都由一个表示块大小的十六进制数字开头,后跟块的实际内容...
Django EventStream EventStream为您的Django应用程序提供API终结点,...Transfer-Encoding: chunked Connection: Transfer-Encoding Content-Type: text/event-stream event: message data: {"foo": "bar"} event:
例如,动态生成的内容大小在响应生成之前未知,或者服务器使用"Transfer-Encoding: chunked"编码。这时,服务器会省略"Content-Length",转而使用分块编码来传输数据。 在实际网络开发中,理解和正确使用"Content-...
通过HTTP的"Transfer-Encoding: chunked"头字段,服务器可以将大文件分成多个小块发送给客户端,客户端每接收完一块就可以开始处理,无需等待整个文件下载完毕。这种方式使得用户可以实现“边下边播”或“即下即用”...
进行Chunked编码传输的HTTP Response会在消息头部设置: Transfer-Encoding: chunked 表示Content Body将用Chunked编码传输内容。 Chunked编码使用若干个Chunk串连而成,由一个标明长度为0的chunk标示结束。每个...
Transfer-Encoding: chunked ``` 2. **数据块**:响应体接着是零个或多个数据块,每个块由块大小(以十六进制表示)和块数据组成。块大小后跟一个CRLF(回车换行符,即`\r\n`),然后是块数据,最后是另一个CRLF...