使服務器支持范圍請求,允許客戶端只請求文檔的一部分。其流程是:
請求中的Ranges頭格式為(這里不考慮多范圍請求了):
Ranges: bytes=[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);以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答