這篇文章主要介紹了nodejs如何實(shí)現(xiàn)范圍請(qǐng)求,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)建站專注于泰興網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供泰興營(yíng)銷型網(wǎng)站建設(shè),泰興網(wǎng)站制作、泰興網(wǎng)頁設(shè)計(jì)、泰興網(wǎng)站官網(wǎng)定制、重慶小程序開發(fā)服務(wù),打造泰興網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供泰興網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。
JS是JavaScript的簡(jiǎn)稱,它是一種直譯式的腳本語言,其解釋器被稱為JavaScript引擎,是瀏覽器的一部分,主要用于web的開發(fā),可以給網(wǎng)站添加各種各樣的動(dòng)態(tài)效果,讓網(wǎng)頁更加美觀。
使服務(wù)器支持范圍請(qǐng)求,允許客戶端只請(qǐng)求文檔的一部分。其流程是:
客戶端向服務(wù)端發(fā)起請(qǐng)求
服務(wù)端響應(yīng),附上Accept-Ranges頭(值表示表示范圍的單位,通常是“bytes”),告訴客戶端其接受范圍請(qǐng)求
客戶端發(fā)送新的請(qǐng)求,附上Ranges頭,告訴服務(wù)端請(qǐng)求的是一個(gè)范圍
服務(wù)端收到范圍請(qǐng)求,分情況響應(yīng):
范圍有效,服務(wù)端返回206 Partial Content,發(fā)送指定范圍內(nèi)內(nèi)容,并在Content-Range頭中指定該范圍
范圍無效,服務(wù)端返回416 Requested Range Not Satisfiable,并在Content-Range中指明可接受范圍
請(qǐng)求中的Ranges頭格式為(這里不考慮多范圍請(qǐng)求了):
Ranges: bytes=[start]-[end]
其中 start 和 end 并不是必須同時(shí)具有:
如果 end 省略,服務(wù)器應(yīng)返回從 start 位置開始之后的所有字節(jié)
如果 start 省略,end 值指的就是服務(wù)器該返回最后多少個(gè)字節(jié)
如果均未省略,則服務(wù)器返回 start 和 end 之間的字節(jié)
響應(yīng)中的Content-Range頭有兩種格式:
當(dāng)范圍有效返回 206 時(shí):
Content-Range: bytes (start)-(end)/(total)
當(dāng)范圍無效返回 416 時(shí):
Content-Range: bytes */(total) //代碼實(shí)現(xiàn) res.setHeader('Content-Range', `bytes */${totalSize}`);
添加函數(shù)處理范圍請(qǐng)求:
【注意】這里吧不合理的范圍請(qǐng)求直接設(shè)置為返回全部,如果想設(shè)置范圍錯(cuò)誤就直接不返回可以設(shè)置http狀態(tài)碼為416
/** * 范圍請(qǐng)求 * 不在合理的范圍內(nèi)就直接返回所有 * 在合理規(guī)范的范圍內(nèi)就按照返回對(duì)應(yīng)的部分 * @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; //不規(guī)范的范圍,是要直接一起返回,所以設(shè)置狀態(tài)碼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;//表示是部分內(nèi)容 //創(chuàng)建一個(gè)流讀取文件, {start, end}表示文件讀取的起始點(diǎn)和終點(diǎn) rs = fs.createReadStream(filePath, { start, end }); } //有這個(gè)pipe就不需要再去調(diào)用end了,這樣直接調(diào)用end會(huì)導(dǎo)致res接受不到東西,因?yàn)閜ipe是異步的 rs.pipe(res);
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“nodejs如何實(shí)現(xiàn)范圍請(qǐng)求”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!