您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Nginx如何配置文件分段下載功能”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Nginx如何配置文件分段下載功能”這篇文章吧。
Html5 提供了一個新的 Range 標簽來實現(xiàn)文件的分段下載。在Node.JS中可以配置這個標簽來實現(xiàn)文件的分段下載。
Header標簽
請求 Request Header: 下載 3744 以后的文件內(nèi)容
range: bytes=3744-
返回 Response Header: 文件總長 15522643 個字節(jié)
accept-ranges': 'bytes' content-range': 'bytes */15522643'
Nginx配置
首先要配置Nginx支持range標簽返回,很簡單添加 add_header Accept-Ranges bytes; 這一行即可
server { listen 80; server_name adksdf.com; location ~ ^/(img/|js/|css/|upload/|font/|fonts/|res/|icon) { add_header Access-Control-Allow-Origin *; add_header Accept-Ranges bytes; root /var/www/...; access_log off; expires max; } ... }
啟用以后,如果node.js端發(fā)送了含有 range header的請求信息,那么nginx會返回含有range相關的信息:
這是一段完整的Response Header,注意這里的 content-length
不是文件的總長度,而是當前 range 的長度。
{ server: 'nginx', date: 'Wed, 24 Jan 2018 02:43:20 GMT', 'content-type': 'application/zip', 'content-length': '12420187', 'last-modified': 'Tue, 16 Jan 2018 12:09:47 GMT', connection: 'close', etag: '"5a5deb8b-ecdb53"', expires: 'Thu, 31 Dec 2037 23:55:55 GMT', 'cache-control': 'max-age=315360000', 'access-control-allow-origin': '*', 'accept-ranges': 'bytes', 'content-range': 'bytes 3102456-15522642/15522643' }
可以根據(jù)這個header中的content-range來獲取文件的總大小。
Node.JS實現(xiàn)
這段示例先檢測本地下了一半的文件,然后以 'r+' 讀寫模式創(chuàng)建文件流,并將response流寫入文件。
這里將表態(tài)文件添加 range 的支持。
var reqOptions = { url: packageUrl, headers: {} } var filepath = '/path/to/your/part/file' var fileOptions = {} fs.stat(filepath, function(err, states) { if (states) { //Range: bytes=3744- reqOptions.headers['range'] = 'bytes=' + states.size + '-' fileOptions = { start: states.size, flags: 'r+' } } //創(chuàng)建 http 對象方法 var reqUrl = reqOptions.url var urlObj = url.parse(reqUrl) var options = { hostname : urlObj.hostname , port : urlObj.port , path : urlObj.pathname , headers : reqOptions.headers || {} } var req = http.request(options, function(res) { var receives = [] var err = null var statusCode = res.statusCode var headers = res.headers var ws = fs.createWriteStream(filepath, fileOptions) ws.on('error', function(e) { console.log('ws error', e) }) res.on('data', function(chrunk) { ws.write(chrunk) }) res.on('error', function(err) { ws.end() }) res.on('end', function() { ws.end() }) }) req.on('error', function(e) { cb && cb(e, null, {}) }) req.end() ... })
返回Header
在請求nginx可能會返回其他status code,比如說 206或416,含意如下:
206 Partial Content
返回的是部分文件內(nèi)容
416 Requested Range Not Satisfiable
請求的range超過文件尺寸
以上是“Nginx如何配置文件分段下載功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。