Node.js实现文件下载

1.设置响应头:

使用 res.writeHead 设置适当的响应头,包括 Content-Type 和 Content-Disposition 以触发下载对话框。
2.创建文件读取流:

使用 fs.createReadStream 创建文件读取流,并通过 pipe 方法将其连接到响应对象 res,从而将文件内容发送给客户端。

javascript 复制代码
const express = require('express');
const path = require('path');
const fs = require("fs");
const router = express.Router();

router.get('/download/example.txt', function(req, res) {
    const filePath = path.join(__dirname, 'example.txt');
    
    // 设置响应头
    res.writeHead(200, {
      'Content-Type': 'application/octet-stream',
      'Content-Disposition': 'attachment; filename="example.txt"'
    });
    
    // 创建文件读取流并将其连接到响应对象
    const fileStream = fs.createReadStream(filePath);
    fileStream.pipe(res);
});
相关推荐
小李子呢02112 分钟前
前端八股CSS---CSS选择器和优先级
前端·css
阿凤215 分钟前
uniapp如何修改下载文件位置
开发语言·前端·javascript
小李子呢02117 分钟前
前端八股---MVVM
前端·javascript·vue.js
神毓逍遥kang10 分钟前
在nest.js中我想把Java的Sa-Token搬来
前端·后端
Sheldon一蓑烟雨任平生11 分钟前
grid(一文读懂 css 网格布局)
前端·css·grid·grid-template·现代css·css 网格布局
砍材农夫17 分钟前
Hermes 搭建可视化web-dashboard界面
前端·人工智能
Z_Wonderful21 分钟前
Qiankun 子应用数据互通 + 资源共享 完整方案(React+Vue)
前端·vue.js·react.js
你的牧游哥21 分钟前
Electron核心api详解
前端·javascript·electron
渣渣xiong34 分钟前
从零开始:前端转型AI agent直到就业第十二天-第十三天
前端·人工智能
05Nuyoah34 分钟前
CSS 基础认知和基础选择器
前端·javascript·css·node.js