nodejs实现范围请求的实现代码


Posted in NodeJs onOctober 12, 2018

使服务器支持范围请求,允许客户端只请求文档的一部分。其流程是:

  1. 客户端向服务端发起请求
  2. 服务端响应,附上Accept-Ranges头(值表示表示范围的单位,通常是“bytes”),告诉客户端其接受范围请求
  3. 客户端发送新的请求,附上Ranges头,告诉服务端请求的是一个范围
  4. 服务端收到范围请求,分情况响应:
    1. 范围有效,服务端返回206 Partial Content,发送指定范围内内容,并在Content-Range头中指定该范围
    2. 范围无效,服务端返回416 Requested Range Not Satisfiable,并在Content-Range中指明可接受范围

请求中的Ranges头格式为(这里不考虑多范围请求了):

Ranges: bytes=[start]-[end]

其中 start 和 end 并不是必须同时具有:

  • 如果 end 省略,服务器应返回从 start 位置开始之后的所有字节
  • 如果 start 省略,end 值指的就是服务器该返回最后多少个字节
  • 如果均未省略,则服务器返回 start 和 end 之间的字节

响应中的Content-Range头有两种格式:

当范围有效返回 206 时:

Content-Range: bytes (start)-(end)/(total)

当范围无效返回 416 时:

Content-Range: bytes */(total)
//代码实现
res.setHeader('Content-Range', `bytes */${totalSize}`);

添加函数处理范围请求:

【注意】这里吧不合理的范围请求直接设置为返回全部,如果想设置范围错误就直接不返回可以设置http状态码为416

/**
 * 范围请求
 * 不在合理的范围内就直接返回所有
 * 在合理规范的范围内就按照返回对应的部分
 * @param {*} totleSize 总的范围
 * @param {*} req 
 * @param {*} res 
 */
module.exports = (totleSize, req, res) => {
  const range = req.headers['range'];
  if (!range) {
    return {code: 200};
  }
 
  const sizes = range.match(/bytes=(\d*)-(\d*)/);
  const end = sizes[2] || totleSize - 1;
  const start = sizes[1] || totleSize - end;
  //不规范的范围,是要直接一起返回,所以设置状态码200
  if(start > end || start < 0 || end > totleSize) {
    return {code: 200};
  }
  res.setHeader('Accept-Ranges', 'bytes');
  res.setHeader('Content_Range', `bytes ${start}-${end}/${totleSize}`);
  res.setHeader('Content_Length', end-start);
  return {
    code: 206,
    start: parseInt(start),
    end: parseInt(end)
  };
};

范围读取:

let rs;
const { code, start, end } = range(stats.size, req, res);
if (code === 200) {
  res.statusCode = 200;
  rs = fs.createReadStream(filePath);
} else {
  res.statusCode = 206;//表示是部分内容
  //创建一个流读取文件, {start, end}表示文件读取的起始点和终点
  rs = fs.createReadStream(filePath, { start, end });
}
 
//有这个pipe就不需要再去调用end了,这样直接调用end会导致res接受不到东西,因为pipe是异步的
rs.pipe(res);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
初始Nodejs
Nov 08 NodeJs
NodeJS制作爬虫全过程
Dec 22 NodeJs
nodejs中实现sleep功能实例
Mar 24 NodeJs
浅谈Nodejs观察者模式
Oct 13 NodeJs
详解nodejs 文本操作模块-fs模块(四)
Dec 22 NodeJs
nodejs入门教程三:调用内部和外部方法示例
Apr 24 NodeJs
nodejs模块学习之connect解析
Jul 05 NodeJs
详解使用vscode+es6写nodejs服务端调试配置
Sep 21 NodeJs
浅谈NodeJs之数据库异常处理
Oct 25 NodeJs
详解Nodejs get获取远程服务器接口数据
Mar 26 NodeJs
基于nodejs的微信JS-SDK简单应用实现
May 21 NodeJs
nodejs文件夹深层复制功能
Sep 03 NodeJs
NodeJS搭建HTTP服务器的实现步骤
Oct 12 #NodeJs
NodeJS服务器实现gzip压缩的示例代码
Oct 12 #NodeJs
nodejs aes 加解密实例
Oct 10 #NodeJs
nodejs读取本地中文json文件出现乱码解决方法
Oct 10 #NodeJs
nodejs require js文件入口,在package.json中指定默认入口main方法
Oct 10 #NodeJs
nodejs更新package.json中的dependencies依赖到最新版本的方法
Oct 10 #NodeJs
nodejs中用npm初始化来创建package.json的实例讲解
Oct 10 #NodeJs
You might like
php 面试碰到过的问题 在此做下记录
2011/06/09 PHP
PHP中is_file()函数使用指南
2015/05/08 PHP
PHP实现的迷你漂流瓶
2015/07/29 PHP
分享50个提高PHP执行效率的技巧
2015/12/26 PHP
关于PHP文件的自动运行方法分析
2016/05/13 PHP
PHP读取大文件的几种方法介绍
2016/10/27 PHP
PHP实现mysqli批量执行多条语句的方法示例
2017/07/22 PHP
自定义jquery模态窗口插件无法在顶层窗口显示问题
2014/05/29 Javascript
浅谈JavaScript中Date(日期对象),Math对象
2015/02/05 Javascript
基于RequireJS和JQuery的模块化编程日常问题解析
2016/04/14 Javascript
javascript解决小数的加减乘除精度丢失的方案
2016/05/31 Javascript
JavaScript必知必会(二) null 和undefined
2016/06/08 Javascript
Angular 4.X开发实践中的踩坑小结
2017/07/04 Javascript
JS实现的新闻列表自动滚动效果示例
2019/01/30 Javascript
微信小程序实现动态列表项的顺序加载动画
2019/07/25 Javascript
layui动态绑定事件的方法
2019/09/20 Javascript
Node.js实现批量下载图片简单操作示例
2020/01/18 Javascript
javascript 函数的暂停和恢复实例详解
2020/04/25 Javascript
bootstrapValidator表单校验、更改状态、新增、移除校验字段的实例代码
2020/05/19 Javascript
Python读取和处理文件后缀为.sqlite的数据文件(实例讲解)
2017/06/27 Python
python使用matplotlib画饼状图
2018/09/25 Python
Django中如何使用sass的方法步骤
2019/07/09 Python
Python中Unittest框架的具体使用
2019/08/27 Python
python实现简单井字棋游戏
2020/03/04 Python
python 基于opencv去除图片阴影
2021/01/26 Python
CSS3绘制不规则图形的一些方法示例
2015/11/07 HTML / CSS
什么是符号链接,什么是硬链接?符号链接与硬链接的区别是什么?
2013/05/03 面试题
如何进行Linux分区优化
2016/09/13 面试题
HR喜欢的自荐信格式
2013/10/08 职场文书
给交警的表扬信
2014/01/12 职场文书
个人安全生产承诺书
2014/05/22 职场文书
幼儿教师自我剖析材料
2014/09/29 职场文书
2014年体育工作总结
2014/11/24 职场文书
2014年社区宣传工作总结
2014/12/02 职场文书
2016年公司新年寄语
2015/08/17 职场文书
css实现两栏布局,左侧固定宽,右侧自适应的多种方法
2021/08/07 HTML / CSS