ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

图解HTTP (chap 3 Http报文内的http信息) 编码提升传输速率(2)

2021-05-02 13:57:31  阅读:187  来源: 互联网

标签:5001 Http 请求 协商 报文 传输速率 Range http 范围


1. 发送多种数据的多部分对象集合

邮件采用了MIME ( Multipurpose Internet Mail Extensions,多用途因特网邮件扩展)机制,它允许邮件附加文本、图片、视频等多个不同类型的数据。
eg. 图片等二进制数据以ASCII码字符串编码的方式指明,就是利用MIME来描述标记数据类型。而在MIME扩展中会使用一种称为多部分对象集合( Multipart )的方法,来容纳多份不同类型的数据。

HTTP协议中也采纳了多部分对象集合,发送的一份报文主体内可含有多类型实体。通常是在图片或文本文件等上传时使用。

  • multipart/form-data
    在Web表单文件上传时候使用

  • multipart/byteranges
    状态码206响应报文包含了多个范围的内容时使用

  • multipart/form-data(在Web表单文件上传时使用)
    在这里插入图片描述

  • multipart/byteranges(状态码206,响应报文包含了多个范围的内容时使用).
    在这里插入图片描述

  • 在HTTP报文中使用多部分对象集合时,需要在首部字段里加上Content-type。

  • 使用boundary字符串来划分多部分对象集合指明的各类实体。在boundary字符串指定的各个实体的起始行之前插入“–”标记,而在多部分对象集合对应的最后插入“–”标记作为结束。

  • 多部分对象集合的每个部分类型中,都可以包含首部字段,可以嵌套使用首部字段

2.获取部分内容的范围请求

内容的范围请求:指定范围发送的请求叫做范围请求,会用到首部字段Range来指定资源的byte范围。
在这里插入图片描述

  • 针对范围请求,响应会返回状态码206PartialContent的响应报文
  • 如果服务器端无法响应范围请求,则会返回状态码200OK和完整的实体内容

2.1 对一份10 000字节大小的资源,如果使用范围请求,可以只请求5001~10 000字节内的资源。

执行范围请求时,会用到首部字段的Range来指定资源的byte范围,bytee的范围指定形式:

  • 5001~10000字节
    Range:bytes = 5001-10000
  • 从5001自己以后的全部
    Range: bytes = 5001-
  • 从一开始到3000字节和5000~7000字节的多重范围
    Range: bytes = -3000,5000-7000

3.内容协商返回最合适的内容

内容协商机制是指客户端和服务器端就响应的资源内容进行交涉,然后提供给客户端最为适合的资源。内容协商会以响应资源的语言、字符集、编码方式等作为判断的基准。

eg. 多语言
在这里插入图片描述

3.1 内容协商技术有三种类型:

  • 服务器驱动协商(Server-driven-Negotiation)
    由服务器端进行协商
  • 客户端驱动协商(Agent-driven Negotition)
    由客户端进行协商
  • 透明协商(Transparent Negotition)
    服务器协商和客户端协商的结合体

标签:5001,Http,请求,协商,报文,传输速率,Range,http,范围
来源: https://blog.csdn.net/thefist11cc/article/details/116353249

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有