【vue3】vue3+express实现图片/pdf等资源文件的下载

文件资源的下载,是我们业务开发中常见的需求。作为前端开发,学习下如何自己使用node的express框架来实现资源的下载操作。

实现效果


代码实现

  • 前端

1.封装的请求后端下载接口的方法,需求配置aixos的请求参数里面的返回数据类型为blob

js 复制代码
// 下载
export function downLoad(name) {
  return instance.get(`/course/download?name=${name}`, {
    responseType: "blob",
  });
}

2.下载的核心方法,这里不能直接后端返回给我们的资源url,因为对于图片和pdf文件,浏览器的首选操作是预览,不是下载本地,所以我们这里需要转换下数据格式。

js 复制代码
const downloadSource = async (item) => {
  const data = await downLoad(item.attachments);
  const blob = new Blob([data]);
  let filename = item.name;
  const fileUrl = item.attachments;

  const extname = fileUrl.substring(fileUrl.lastIndexOf(".") + 1);
  filename = filename + "." + extname;

  const link = document.createElement("a");
  link.download = filename;
  link.target = "_blank";
  link.style.display = "none";
  link.href = URL.createObjectURL(blob);
  document.body.appendChild(link);
  link.click();
  URL.revokeObjectURL(link.href);
  document.body.removeChild(link);
};

3.后端响应的数据格式

  • 后端
    1.模拟数据

2.后端接口方法,"Content-Disposition这个响应头表示资源是需要下载的,如果含有中文可能会报错,解决方法是只需要我们encodeURIComponent转译就行了。

js 复制代码
//下载资料
const imagePath = (name) => path.join(__dirname, `../public/images/${name}`);
const downloadFile = (req, res, next) => {
  // console.log("🚀 ~ fs.readFile ~ imagePath:", req.query.name);
  const nameArr = req.query.name.split("/");
  fs.readFile(imagePath(nameArr[nameArr.length - 1]), (err, buffer) => {
    if (err) {
      res.status(500).send("Error reading image");
      return;
    }
    // 设置响应头
    switch (req.query.name) {
      case "pdf":
        res.setHeader("Content-Type", "application/pdf");
        break;
      default:
        res.setHeader("Content-Type", "image/jpeg");
    }

    // 设置响应头
    res.setHeader("Content-Type", "application/pdf");
    res.setHeader(
      "Content-Disposition",
      `attachment; filename=${encodeURIComponent(nameArr[nameArr.length - 1])}`
    );

    // 发送图片数据
    res.send(buffer);
  });
};

3.配置请求方法路径

这样我们就实现了图片,pdf等资源的下载。这里只演示了图片和资源两种文件类型,其余的类型是一样的原理,可以自行添加测试。

相关推荐
还是大剑师兰特几秒前
Pinia介绍及Vue3配置示例
前端·javascript·vue.js
还是大剑师兰特12 分钟前
Vue3 Mixin 与 Vue2 Mixin 核心区别
前端·javascript·vue.js
188号安全攻城狮15 分钟前
【前端基础知识】JavaScript 数组方法总结:从表格速查到分类详解
开发语言·前端·javascript·网络安全
英俊潇洒美少年19 分钟前
迷你 React 调度器(带优先级+时间切片)手写实现
前端·javascript·react.js
freeWayWalker41 分钟前
Vue通用缩放容器
前端·javascript·vue.js
Hello--_--World1 小时前
VUE:逻辑复用
前端·javascript·vue.js
陶甜也1 小时前
3D智慧城市:blender建模、骨骼、动画、VUE、threeJs引入渲染,飞行视角,涟漪、人物行走
前端·3d·vue·blender·threejs·模型
叫我一声阿雷吧1 小时前
JS 入门通关手册(43):async/await 原理与异常处理(实战 + 面试,彻底搞懂)
javascript·异常处理·promise·前端面试·async/await·generator·异步编程
小陈工5 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
NPCZ9 小时前
vite与tailwindcss创建大屏可视化项目
vue