淺析Node.js實現(xiàn)HTTP文件下載
前言
HTTP實現(xiàn)文件下載時,只要在服務器設置好相關響應頭,并使用二進制傳輸文件數(shù)據(jù)即可,而客戶端(瀏覽器)會根據(jù)響應頭接收文件數(shù)據(jù)。而在Node.js中,設置好響應頭后,讀取文件流,再使用“.pipe()”方法將流轉接到響應對象Response就可以實現(xiàn)一個簡單的文件下載服務器。
1. 文件下載介紹
HTTP基于請求頭和響應頭實現(xiàn)狀態(tài)交互,在得到服務器正確響應狀態(tài)后,而客戶端首先會解析響應頭,并根據(jù)響應頭來接收和展示數(shù)據(jù)(響應體)。對于文件下載來說,其實現(xiàn)過程如下:
1.客戶端發(fā)起文件資源請求
2.服務器查找對應文件,并設置”Content-Type”、”Content-Disposition”等響應頭,分別用于表示文件的”MIME”類型及文件描述
3.客戶端根據(jù)服務器返回的響應頭解析和接收文件數(shù)據(jù)
需要設置的響應頭
設置文件下載響應頭時,除了常用的HTTP響應頭外,比較重要是還要設置以下兩個響應頭:
Content-Type: application/octet-stream Content-Disposition: attachment; filename=MyFileName.ext
在上面的設置中,”Content-Type: application/octet-stream”告訴瀏覽器這是一個二進制文件,”Content-Disposition”告訴瀏覽器這是一個需要下載的附件并告訴瀏覽器默認的文件名。如果不添加”Content-Disposition”響應頭,瀏覽器可能會下載或顯示文件內容,不同瀏覽器的處理有所不同。
2. Node.js文件下載服務器實現(xiàn)
接下來我們基于Express 框架實現(xiàn)一個簡單文件下載服務器,在這個服務器中主要包括兩個功能:服務器文件的瀏覽、文件的下載。
2.1 添加路由
創(chuàng)建Express應用后,添加如下兩個路由:
router.get('/files', function(req, res, next) {
// 顯示服務器文件
});
router.get('/file/:fileName', function(req, res, next) {
// 實現(xiàn)文件下載
});
上面的添加的兩個路由分別用于:顯示服務器文件、實現(xiàn)文件下載。
2.2 顯示服務器文件
實現(xiàn)服務器文件的顯示,要通過”fs”模塊讀取文件目錄并進行文件/目錄檢查等。還需要使用”path”模塊處理文件路徑。首先引入這兩個模塊:
const fs = require('fs');
const path = require('path');
顯示服務器文件實現(xiàn)代碼如下:
router.get('/files', function(req, res, next) {
// 顯示服務器文件
// 文件目錄
var filePath = path.join(__dirname, './');
fs.readdir(filePath, function(err, results){
if(err) throw err;
if(results.length>0) {
var files = [];
results.forEach(function(file){
if(fs.statSync(path.join(filePath, file)).isFile()){
files.push(file);
}
})
res.render('files', {files:files});
} else {
res.end('當前目錄下沒有文件');
}
});
});
上面代碼中,讀取目錄后通過視圖文件”files.ejs”顯示可下載文件列表。其代碼如下:
<!DOCTYPE html>
<html>
<head>
<title>下載文件選擇</title>
</head>
<body>
<h1>請選擇下載文件:</h1>
<% if(files.length>0) {%>
<ul>
<% files.forEach(function(file){ %>
<li>
<a href="/file/<%- file %>" target="_blank"><%- file %></a>
</li>
<%})%>
</ul>
<%} else {%>
<p>沒有可下載文件…</p>
<%}%>
</body>
</html>
2.3 實現(xiàn)文件下載
實現(xiàn)文件下載時,可以先讀取文件到一個”Buffer”中,再通過”res.send()”或”res.end()”方法發(fā)送文件數(shù)據(jù),也可以基于流(”Stream”)實現(xiàn)文件數(shù)據(jù)的發(fā)送。使用”Stream”實現(xiàn)文件下載時,可以使用”fs.createReadStream()”方法創(chuàng)建一個可讀流,而響應對象Response是一個可寫流。這樣,只需要通過”.pipe()”方法將文件流轉接到Response響應流中即可。
文件下載實現(xiàn)代碼如下:
router.get('/file/:fileName', function(req, res, next) {
// 實現(xiàn)文件下載
var fileName = req.params.fileName;
var filePath = path.join(__dirname, fileName);
var stats = fs.statSync(filePath);
if(stats.isFile()){
res.set({
'Content-Type': 'application/octet-stream',
'Content-Disposition': 'attachment; filename='+fileName,
'Content-Length': stats.size
});
fs.createReadStream(filePath).pipe(res);
} else {
res.end(404);
}
});
總結
以上就是利用Node.js實現(xiàn)HTTP文件下載的全部內容,希望對大家學習Node.js有所幫助。
- Node.js的Express框架使用上手指南
- 從零開始學習Node.js系列教程之基于connect和express框架的多頁面實現(xiàn)數(shù)學運算示例
- node.js使用express框架進行文件上傳詳解
- node.js express框架簡介與實現(xiàn)
- Node.js + express實現(xiàn)上傳大文件的方法分析【圖片、文本文件】
- node.js(express)中使用Jcrop進行圖片剪切上傳功能
- Node.js 使用request模塊下載文件的實例
- Node.JS段點續(xù)傳:Nginx配置文件分段下載功能的實現(xiàn)方法
- 基于nodejs+express4.X實現(xiàn)文件下載的實例代碼
- nodejs+express實現(xiàn)文件上傳下載管理網(wǎng)站
- 使用nodejs+express實現(xiàn)簡單的文件上傳功能
- node.js express框架實現(xiàn)文件上傳與下載功能實例詳解
相關文章
NodeJS連接MySQL數(shù)據(jù)庫并進行增刪改查操作詳解
本篇是使用NodeJS的模塊MySQL操作MySQL數(shù)據(jù)庫的基礎教程,連接MySQL數(shù)據(jù)庫并進行增刪改查操作詳解,需要的朋友可以參考下2024-02-02
Node.JS利用PhantomJs抓取網(wǎng)頁入門教程
現(xiàn)今,網(wǎng)頁抓取已經是一種人所共知的技術了,然而依然存在著諸多復雜性,下面這篇文章主要給大家介紹了Node.JS利用PhantomJs抓取網(wǎng)頁的方法教程,需要的朋友可以參考借鑒,下面來一起看看吧。2017-05-05
k8s node節(jié)點重新加入master集群的實現(xiàn)
這篇文章主要介紹了k8s node節(jié)點重新加入master集群的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02
nodejs使用PassThrough流進行數(shù)據(jù)傳遞合并示例詳解
這篇文章主要為大家介紹了nodejs使用PassThrough流進行數(shù)據(jù)傳遞合并示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09

