Http - content-length 了解

Http - content-length 了解

Content-Length

Content-Length是HTTP消息长度, 用十进制数字表示的八位字节的数目, 是Headers中常见的一个字段. Content-Length应该是精确的, 否则就会导致异常 (特别地, HTTP1.0中这个字段可有可无).

Content-Length首部指示出报文中实体主体的字节大小. 这个大小是包含了所有内容编码的, 比如, 对文本文件进行了gzip压缩的话, Content-Length首部指的就是压缩后的大小而不是原始大小

Content-length 长度与实际长度不一致

Content-Length, HTTP消息长度, 用十进制数字表示的八位字节的数目. 一般情况下, 很多工作都被框架完成, 我们很少去关注这部分内容, 但少数情况下发生了Content-Length与实际消息长度不一致, 程序可能会发生比较奇怪的异常, 如:

  • 请求时长度不一致
    • 无响应直到超时.
  • 响应时长度不一致
    • 请求被截断, 而且下一个请求解析出现错乱

Content-Length 工作原理

Content-Length使用十进制的数字表示了消息的长度, 服务端/客户端通过它来得知后续要读取消息的长度

Transfer-Encoding

当请求处理完成前无法获取消息长度, 我们就无法明确指定Content-Length, 此时应该使用Transfer-Encoding: chunked

什么是Transfer-Encoding: chunked

数据以一系列分块的形式进行发送. Content-Length 首部在这种情况下不被发送. 在每一个分块的开头需要添加当前分块的长度, 以十六进制的形式表示,后面紧跟着 \r\n , 之后是分块本身, 后面也是\r\n. 终止块是一个常规的分块, 不同之处在于其长度为0

Transfer-Encodeing 工作原理

在wireshark中可以很清晰地看到chunked的数据, 其结构大致是: 返回的消息被分为多个数据块, 每个数据块有两部分, 长度 + 数据, 这两部分都以CRLF(即\r\n)结尾. 而终止块是一个特殊的数据块, 其长度为0

结论

  • Content-Length如果存在且生效, 必须是正确的, 否则会发生异常.(大于实际值会超时, 小于实际值会截断并可能导致后续的数据解析混乱)
  • 如果报文中包含Transfer-Encoding: chunked首部, 那么Content-Length将被忽略
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: content-disposition 是 HTTP 协议中的一个头部字段,用于指示如何处理被请求的消息体。通常,它被用于下载文件时,指示浏览器以何种方式处理下载文件的响应。 获取 content-disposition 的方式取决于你是在客户端还是服务端。如果你是在客户端,可以使用浏览器的开发者工具查看响应头部中是否包含 content-disposition 字段。如果你是在服务端,可以查看响应头部的 content-disposition 字段来获取其值。 以下是一个示例 HTTP 响应,其中包含 content-disposition 字段: ``` HTTP/1.1 200 OK Content-Type: application/octet-stream Content-Disposition: attachment; filename="example.txt" Content-Length: 1234 <file content> ``` 在这个示例中,content-disposition 的值是 attachment; filename="example.txt",指示浏览器应该将响应的消息体作为附件下载,并将文件名设置为 example.txt。 ### 回答2: 获取content-disposition可以通过以下几种方式实现: 1. 前端通过发送HTTP请求获取响应头中的content-disposition字段。可以使用XMLHttpRequest对象或fetch函数发送异步请求,并通过getResponseHeader方法获取content-disposition的值。 2. 在使用fetch函数发送请求时,可以通过设置请求的credentials属性为include,以便在跨域请求时,服务器可以将带有content-disposition字段的响应头发送给前端。 3. 如果前端使用的是某个特定的JavaScript库,如axios,可以查看库的文档,了解是否提供了获取响应头的方法,如通过拦截响应的方式。 需要注意的是,获取content-disposition字段可能会受到跨域资源共享(CORS)策略的限制。如果服务器没有明确允许前端访问content-disposition字段,前端将无法获取到该字段的值。在这种情况下,可以考虑使用服务器端的代理来获取content-disposition的值,并将其传递给前端。 总结起来,前端可以通过发送HTTP请求并获取响应头中的content-disposition字段来获取该字段的值。具体的实现方法可以根据前端所使用的技术栈和环境进行调整。 ### 回答3: 前端无法直接获取`content-disposition`,因为`content-disposition`是HTTP响应头部字段,在前端无法直接访问和获取。`content-disposition`常用于指定服务器响应的文件名称和下载方式。 前端可以通过发送HTTP请求并获取响应头部来获取`content-disposition`。常见的方法是使用AJAX或Fetch来发送请求,然后在返回的响应头部中查找`content-disposition`字段。 以下是一个示例使用Fetch API获取`content-disposition`的方法: ```JavaScript fetch('http://example.com/file', { method: 'GET', headers: { 'Content-Type': 'application/octet-stream', }, }) .then(response => { const contentDisposition = response.headers.get('content-disposition'); console.log(contentDisposition); }) .catch(error => { console.log(error); }); ``` 这段代码通过使用Fetch API发送一个GET请求到`http://example.com/file`,然后从响应头部中获取`content-disposition`字段的值,并将其打印到控制台。 需要注意的是,跨域请求需要在服务器端设置适当的响应头部,以允许前端访问响应头部。否则,浏览器将会阻止前端获取其他域的响应头部,以保护用户的安全和隐私。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值