HTTP chunked+gzip及浏览器兼容测试(转载自ifreax的blog)
2012-04-06 17:29
375 查看
简述:
QQ空间提出一个需求,要求qzhttp支持chunked+gzip。每个chunk是一个独立的gzip压缩包,并提到雅虎是这么实现的。
分析结论:
1.雅虎的chunked+gzip的方式,每个chunk并不是一个独立的gzip压缩包。
2.如果采用chunked+gzip方式,并且每个chunk都是一个gzip压缩包的方式,浏览器不支持(用ie和chrome测试)。
一. 首先对于雅虎搜索chunked+gzip的一个抓包分析。
第一段chunk,前2个字节是标准的gzip包头0x1f8b
第二段chunk,前2个字节则不是标准的gzip包头。
如果将yahoo的http回包中头字段和chunk控制字段去掉保存起来,会得到一个标准的gzip包,可以用7-zip打开。
所以yahoo搜索的chunked+gzip模式中的每个chunk并不是一个可独立解压的gzip包。
二. 关于对浏览器对chunked+gzip的支持测试。
为了快速测试,用php脚本实现了一个简单的web
server。(见下)
1. 每个chunk单独压缩。
用cat参数启动server (server的php脚本见下)
./chunked_gzip.php cat
从图中可以看到分了三个chunk,每个chunk都是一个标准的gzip压缩包。
对应php中的代码:
IE对此的反应是只显示的第一个chunk.
Chrome对此的反应是正确显示第一个chunk,其它的就乱来了。
2. 如果将整个包体压缩成一个gzip包,然后分成多个chunk。
用dog参数启动server(server
php脚本见附件)
./trucked_gzip.php dog
从图中可以看到所有的chunk合在一起是一个压缩包,gzip标准头只出现了一次0x1f8b。
对应php server里面的代码是:
IE对此的反应是能正确显示。
Chrome对此的反应同样的正确的。
三. 在wikipedia上有对于chunked+gzip是不是分段压缩的明确说明
原文:HTTP servers sometimes use compression (gzip or deflate) to allow reducing time spent for transmission.
Chunked transfer encoding can be used to delimit parts of the compressedobject. In
this case, it is worth noting that the chunks are not individually
compressed.Instead, the complete payload is compressed and the output of the compression process is chunked using the scheme described in this
article.
译:http server 有时候用压缩来减少传输时间。Chunked方式可以将压缩后的数据分成好几块。在这种情况下,值得注意的是这些chunks并不是分别(独立)被压缩的,相反,整个压缩处理后的输出再用前面讲到的chunked方式传输。
http://en.wikipedia.org/wiki/Chunked_transfer_encoding
php测试脚本代码:
QQ空间提出一个需求,要求qzhttp支持chunked+gzip。每个chunk是一个独立的gzip压缩包,并提到雅虎是这么实现的。
分析结论:
1.雅虎的chunked+gzip的方式,每个chunk并不是一个独立的gzip压缩包。
2.如果采用chunked+gzip方式,并且每个chunk都是一个gzip压缩包的方式,浏览器不支持(用ie和chrome测试)。
一. 首先对于雅虎搜索chunked+gzip的一个抓包分析。
第一段chunk,前2个字节是标准的gzip包头0x1f8b
第二段chunk,前2个字节则不是标准的gzip包头。
如果将yahoo的http回包中头字段和chunk控制字段去掉保存起来,会得到一个标准的gzip包,可以用7-zip打开。
所以yahoo搜索的chunked+gzip模式中的每个chunk并不是一个可独立解压的gzip包。
二. 关于对浏览器对chunked+gzip的支持测试。
为了快速测试,用php脚本实现了一个简单的web
server。(见下)
1. 每个chunk单独压缩。
用cat参数启动server (server的php脚本见下)
./chunked_gzip.php cat
从图中可以看到分了三个chunk,每个chunk都是一个标准的gzip压缩包。
对应php中的代码:
IE对此的反应是只显示的第一个chunk.
Chrome对此的反应是正确显示第一个chunk,其它的就乱来了。
2. 如果将整个包体压缩成一个gzip包,然后分成多个chunk。
用dog参数启动server(server
php脚本见附件)
./trucked_gzip.php dog
从图中可以看到所有的chunk合在一起是一个压缩包,gzip标准头只出现了一次0x1f8b。
对应php server里面的代码是:
IE对此的反应是能正确显示。
Chrome对此的反应同样的正确的。
三. 在wikipedia上有对于chunked+gzip是不是分段压缩的明确说明
原文:HTTP servers sometimes use compression (gzip or deflate) to allow reducing time spent for transmission.
Chunked transfer encoding can be used to delimit parts of the compressedobject. In
this case, it is worth noting that the chunks are not individually
compressed.Instead, the complete payload is compressed and the output of the compression process is chunked using the scheme described in this
article.
译:http server 有时候用压缩来减少传输时间。Chunked方式可以将压缩后的数据分成好几块。在这种情况下,值得注意的是这些chunks并不是分别(独立)被压缩的,相反,整个压缩处理后的输出再用前面讲到的chunked方式传输。
http://en.wikipedia.org/wiki/Chunked_transfer_encoding
php测试脚本代码:
相关文章推荐
- HTTP chunked+gzip及浏览器兼容测试 转
- HTTP chunked+gzip及浏览器兼容测试
- 在线HTTP速度测试(响应时间测试)及浏览器兼容测试
- 浏览器是怎样工作的(一):基础知识 转载http://ued.ctrip.com/blog/how-browsers-work-i-basic-knowledge.html
- 转载:javascript 获取 浏览器body高宽等 (兼容多个浏览器:IE Firefox google apple 测试通过)
- 在线HTTP速度测试(响应时间测试)及浏览器兼容测试
- c++中的srand()和rand() 转载 自:http://blog.sina.com.cn/s/blog_624c2c4001012f67.html
- windows下安装nginx (转载自:http://blog.163.com/njut_wangjian/blog/static/1657964252013327103716818/)
- 泛型与反射(转载http://blog.csdn.net/hivon/)
- 浏览器兼容问题,一直是自己最头疼,一直回避的问题,今天看得到了一些启发,发奋今天开始研究这个,哈哈,以下为转载文章,好好学习。
- 浅析值类型与引用类型的内存分配[转载]http://blog.csdn.net/yuchen_0515/article/details/5330106
- 内部软件就不用做UI测试及浏览器兼容测试吗?
- GDI中的坐标映射问题 (转载自http://blog.csdn.net/huawdai/archive/2002/01/15/6169.aspx)
- 【转载】IE6 浏览器常见兼容问题 大汇总(23个)
- 跨浏览器兼容测试8大利器
- WebSocket(3)-- WebSocket协议简介[转载自http://blog.csdn.net/yl02520/article/]
- 转载http://z-xiaofei168.iteye.com/blog/1044843 spring事务管理
- 转载http://blog.csdn.net/jojoaric/archive/2006/10/17/1338763.aspx
- 跨浏览器兼容测试8大利器
- 动态表单——个人心得,转载请注明出处:http://blog.csdn.net/coolwzjcool