www.6766.comnodejs实现范围请求的实现代码_node.js_脚本之家

一倡百和中的Content-Range头有二种格式:

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

当范围无效再次来到 416 时:

以上便是本文的全体内容,希望对我们的学习抱有帮助,也意在我们多多指教脚本之家。

顾客端向服务端发起呼吁服务端响应,附上Accept-Ranges头(值表示表示范围的单位,通常是“bytes”),告诉顾客端其承当范围请求客户端发送新的乞请,附上Ranges头,告诉服务端央求的是一个限量
服务端收到范围央求,分情形响应: 范围有效,服务端重回206 Partial
Content,发送钦点范围Nene容,并在Content-Range头中钦赐该限量
范围无效,服务端再次回到416 Requested Range Not
Satisfiable,并在Content-Range中指明可接收范围

当范围有效重回 206 时:

此处呢不客观的界定央求直接设置为回到全体,如若想设置节制错误就直接不回来能够安装http状态码为416

里头 start 和 end 并不是必须同有的时候候具有:

增添函数管理范围伏乞:

使服务器扶植范围央求,允许客商端只乞请文书档案的一有些。其流程是:

恳请中的Ranges头格式为:

/** * 范围请求 * 不在合理的范围内就直接返回所有 * 在合理规范的范围内就按照返回对应的部分 * @param {*} totleSize 总的范围 * @param {*} req * @param {*} res */module.exports =  => { const range = req.headers['range']; if  { return {code: 200}; } const sizes = range.match; 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, end: parseInt };};

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

只要 end 省略,服务器应重返从 start 地点上马现在的具有字节 如若 start
省略,end 值指的就是服务器该再次来到倒数字节
假设均未省略,则服务器再次回到 start 和 end 之间的字节

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图