内容简介:其可选值有:也可以同时指定多个值,用逗号分隔,像这样:
Transfer-Encoding
响应头用于告诉客户端服务器发送内容的编码格式。
其可选值有:
-
chunked
:数据分块发送。此时应缺省Content-Length
响应头。 -
compress
:使用 Lempel-Ziv-Welch 算法进行传输的格式,目前没有浏览器在支持。 -
deflate
:使用 deflate 压缩算法 zlib 结构。 -
gzip
:使用 Lempel-Ziv coding 编码的压缩格式。 -
identity
:标识身份函数(e.g. no compression, nor modification)。
也可以同时指定多个值,用逗号分隔,像这样: Transfer-Encoding: gzip, chunked
。
其中, chunked
就比较有意思了。它表示服务器下发到客户端的内容不是一次性完成的,而是分成一小块一小块(trunk)下发,过程中客户端与服务器的连接仍然维持不会断开。
在 Web Socket 没出来前,可利用这一机制实现长连接的效果。
示例
以 Node.js 为例的 Transfer-Encoding: gzip, chunked
示例:
var http = require("http"); function generateChunk(index, response) { setTimeout(() => { if (index === 5) { response.write("end"); response.end("</body></html>"); } else { response.write(`<p> chunk ${index}</p>`); } }, index * 1000); } function handlerRequest(_request, response) { response.setHeader("Content-Type", "text/html; charset=UTF-8"); response.setHeader("Transfer-Encoding", "chunked"); response.write(`<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>HTTP 分块传输示例</title> </head> <body> <h1>HTTP 分块传输示例</h1> `); let index = 0; while (index <= 5) { generateChunk(index, response); index++; } } const server = http.createServer(handlerRequest); server.listen(3000); console.log("server started at http://localhost:3000");
Transfer-Encoding:chunked 分块传输示例
总结
HTTP/2 中已经不支持 chunked
这一格式了,因为其本身提供了更加高级的流机制来实现类似功能。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 利用分块传输吊打所有WAF
- 编写Burp分块传输插件绕WAF
- 从零开始学算法:6.链表与分块
- 从零开始一个文件分块上传【后端为Golang】
- 【火炉炼AI】机器学习037-NLP文本分块
- Flutter-Http分块下载与断点续传
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
迎接互联网的明天
邹静 / 电子工业 / 2011-6 / 55.00元
《迎接互联网的明天-玩转3D Web(附盘)》,全书共5章,第1章主要阐述了国内外空前繁荣的3D互联网技术领域,以及这些领域透射出来的潜在商机;第2章主要用当下比较流行的Flash编程语言ActionScript 3,来向大家介绍面向对象编程语言的思想概念,以及一些3D渲染技术的入门知识;第3章注重建模知识的运用,主要运用WireFusion和3ds Max来制作3D网页;第4章主要介绍3D游戏编......一起来看看 《迎接互联网的明天》 这本书的介绍吧!