[HTTP-3]-HTTP报文内的HTTP信息(下)
Posted 他们已经在路上了
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[HTTP-3]-HTTP报文内的HTTP信息(下)相关的知识,希望对你有一定的参考价值。
接着上节内容,我们继续针对HTTP报文内的HTTP信息进行讲解。
4.发送多种数据的多部分对象合集
相应地,HTTP协议中也采纳了多部分对象集合,发送的一份报文主体内可含有多类型实体。通常是在图片或文本文件等上传时使用。
多部分对象集合包含的对象如下:
(1)multipart/form-data:
在Web表单文件上传时使用。
(2)multipart/byteranges:
状态码 206(Partial Content,部分内容)响应报文包含了多个范 围的内容时使用。
(3)multipart/form-data:
Content-Type: multipart/form-data;**boundary=AaB03x
--AaB03x
Content-Disposition: form-data; name="field1"
Joe Blow
--AaB03x
Content-Disposition: form-data; name="pics"; filename="file1.txt"
Content-Type: text/plain
...(file1.txt的数据)...
--AaB03x--
(4)multipart/byteranges:
HTTP/1.1 206 Partial Content
Date: Fri, 13 Jul 2012 02:45:26 GMT
Last-Modified: Fri, 31 Aug 2007 02:02:20 GMT
Content-Type: multipart/byteranges; boundary=THIS_STRING_SEPARATES
--THIS_STRING_SEPARATES
Content-Type: application/pdf
Content-Range: bytes 500-999/8000
...(范围指定的数据)...
--THIS_STRING_SEPARATES
Content-Type: application/pdf
Content-Range: bytes 7000-7999/8000
...(范围指定的数据)...
--THIS_STRING_SEPARATES--
使用boundary字符串来划分多部分对象集合指明的各类实体。在boundary字符串指明的各个实体的起始行之前插入“--”标记(例如:--AaB03x、--THIS STRINGSEPARATES),而在多部分对象集合对应的字符串的最后插入”--“标记(例如:--AaB03x--、--THISSTRING_SEPARATES--)作为结束。
多部分对象集合的每个部分类型中,都可以含有首部字段。另外,可以在某个部分中嵌套使用多部分对象集合。有关多部分对象集合更详细的解释,请参考RFC2046。
5.获取部分内容的范围请求
下载中断导致重新下载:
以前,用户不能使用现在这种高速的带宽访问互联网,当时,下载一个尺寸稍大的图片或文件就已经很吃力了。如果下载过程中遇到网络中断的情况,那就必须重头开始。为了解决上述问题,需要一种可恢复机制。所谓恢复是指能从之前下载中断处恢复下载。
要实现该功能需要指定下载的实体范围。像这样指定范围发送的请求叫做范围请求。
对一份10 000字节大小的资源,如果使用范围请求,可以只请求5001~10 000字节内的资源。
例如:
客户端:
GET/tip.jpg HTTP/1.1
Host:ww.usagidesign.jp
Range:bytes=5001-10000
服务器端:
HTTP/1.1 206 Partial Content
Date:Fri, 13 Jl 2012 04:39:17 GMT
Content-Range:bytes 5001-10000/10000
Content-Length:5000
Content-Type:image/jpeg
执行范围请求时,会用到首部字段Range来指定资源的byte范围。
byte范围的指定形式如下:
(1)5001~10 000字节
Range: bytes=5001-10000
(2)从5001字节之后全部的
Range: bytes=5001
(3)从一开始到3000字节和5000~7000字节的多重范围
Range: bytes=-3000,5000-7000
如果服务器端无法响应范围请求,则会返回状态码200 OK和完整的实体内容。
6.内容协商返回最合适的内容
同为一个Web网站又可能存在着多份相同内容的页面。比如英文版和中文版的Web页面,他们内容上虽然相同,但使用的语言却不同。
当浏览器的默认语言为英文或中文,访问相同的URI的Web页面时,则会显示对应的英语版或中文版的Web页面。这样的机制成为内容协商。
内容协商机制是指客户端和服务器端就响应的资源进行交涉,然后提供给客户端最为合适的资源。内容协商会以响应资源的语言、字符集、编码方式等作为判断的基准。
包含在请求报文中的某些首部字段就是判断基准。这些首部字段的详细说明请参考下一章,下面先讲有哪些首部字段是作为内容协商的判断基准的:
Accept
Accept-Charset
Accept-Encoding
Accept-Language
Content-Lauguage
内容协商技术有以下3种类型:
(1)服务器驱动协商(Server-driven Negotiation)
由服务器端进行内容协商。以请求的首部字段为参考,在服务器端自动处理。但对于用户来说,以浏览器发送的信息作为判定的依据,并不一定能筛选出最优内容。
(2)客户端驱动协商(Agent-driven Negotiation)
由客户端进行内容协商的方式。用户从浏览器显示的可选项列表中手动选择。还可以利用javascript脚本在Web页面上自动进行上述选择。比如按OS的类型或浏览器类型,自行切换成PC端页面或手机版页面。
(3)透明协商(Transparent Negotiation)
是服务器驱动和客户端驱动的结合,是由服务器端和客户端各自进行内容协商的一种方法。
以上就是本节内容,我们下节来讲讲返回结果的 HTTP 状态码。
以上是关于[HTTP-3]-HTTP报文内的HTTP信息(下)的主要内容,如果未能解决你的问题,请参考以下文章
(第三章,第四章)http报文内的http信息,返回结果的http状态码