vue实现下载文件流完整前后端代码


Posted in Vue.js onNovember 17, 2020

使用Vue时,我们前端如何处理后端返回的文件流

首先后端返回流,这里我把流的动作拿出来了,我很多地方要用

/**
 * 下载单个文件
 *
 * @param docId
 */
 @GetMapping("/download/{docId}")
 public void download(@PathVariable("docId") String docId,
       HttpServletResponse response) {
  outWrite(response, docId);
 }
 
 /**
 * 输出文件流
 * @param response
 * @param docId
 */
 private void outWrite(HttpServletResponse response, String docId) {
  ServletOutputStream out = null;
  try {
   out = response.getOutputStream();
   // 禁止图像缓存。
   response.setHeader("Pragma", "no-cache");
   response.setHeader("Cache-Control", "no-cache");
   response.setDateHeader("Expires", 0);
   byte[] bytes = docService.downloadFileSingle(docId);
   if (bytes != null) {
    MagicMatch match = Magic.getMagicMatch(bytes);
    String mimeType = match.getMimeType();
    response.setContentType(mimeType);
    out.write(bytes);
   }
   out.flush();
  } catch (Exception e) {
   UnitedLogger.error(e);
  } finally {
   IOUtils.closeQuietly(out);
  }
 }

前端这里我引入了一个组件 js-file-download

npm install js-file-download --save

然后在Vue文件中添加进来

import fileDownload from "js-file-download";

 // 文档操作列对应事件
 async handleCommand(item, data) {
  switch (item.key) {
  case "download":
   var res = await this.download(data);
   return fileDownload(res, data.name);
  ...
  default:
  }
  // 刷新当前层级的列表
  const folder = this.getLastFolderPath();
  this.listClick(folder.folderId, folder.name);
 },
 // 下载
 async download(row) {
  if (this.isFolder(row.type)) {
  return FolderAPI.download(row.id);
  } else {
  return DocAPI.download(row.id);
  }
 },

docAPI js 注意需要设置responseType

/**
 * 下载单个文件
 * @param {*} id
 */
const download = (id) => {
 return request({
 url: _DataAPI.download + id,
 method: "GET",
 responseType: 'blob'
 });
};

这样即可成功下载。

关于vue.js的学习教程,请大家点击专题vue.js组件学习教程、Vue.js前端组件学习教程进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
详解Vue的mixin策略
Nov 19 Vue.js
Vue仿百度搜索功能
Dec 28 Vue.js
vue中配置scss全局变量的步骤
Dec 28 Vue.js
vuex的使用和简易实现
Jan 07 Vue.js
vue实现一个获取按键展示快捷键效果的Input组件
Jan 13 Vue.js
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
Vue接口封装的完整步骤记录
May 14 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
vue cli4中mockjs在dev环境和build环境的配置详情
Apr 06 Vue.js
Vue操作Storage本地化存储
Apr 29 Vue.js
vue-cli3.x配置全局的scss的时候报错问题及解决
Apr 30 Vue.js
vue+iview实现文件上传
Nov 17 #Vue.js
vue中echarts的用法及与elementui-select的协同绑定操作
Nov 17 #Vue.js
vue+iview实现分页及查询功能
Nov 17 #Vue.js
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 #Vue.js
vue+iview分页组件的封装
Nov 17 #Vue.js
在vue中通过render函数给子组件设置ref操作
Nov 17 #Vue.js
vue+vant实现购物车全选和反选功能
Nov 17 #Vue.js
You might like
终于听上了直流胆调频
2021/03/02 无线电
PHP技术开发技巧分享
2010/03/23 PHP
PHP json_encode中文乱码问题的解决办法
2013/09/09 PHP
PHP生成Gif图片验证码
2013/10/27 PHP
PHP中source #N问题的解决方法
2014/01/27 PHP
浅析PHP微信支付通知的处理方式
2014/05/25 PHP
php递归删除目录与文件的方法
2015/01/30 PHP
php获取当前页面完整URL地址
2015/12/30 PHP
php+jQuery+Ajax实现点赞效果的方法(附源码下载)
2020/07/21 PHP
使用jQuery的将桌面应用程序引入浏览器
2010/11/19 Javascript
jQuery源码分析-05异步队列 Deferred 使用介绍
2011/11/14 Javascript
js multiple全选与取消全选实现代码
2012/12/04 Javascript
原生Js实现元素渐隐/渐现(原理为修改元素的css透明度)
2013/06/24 Javascript
JavaScript字符串插入、删除、替换函数使用示例
2013/07/25 Javascript
只需一行代码,轻松实现一个在线编辑器
2013/11/12 Javascript
js取消单选按钮选中并判断对象是否为空
2013/11/14 Javascript
利用javaScript实现点击输入框弹出窗体选择信息
2013/12/11 Javascript
jquery实现checkbox全选全不选的简单实例
2013/12/31 Javascript
checkbox全选所涉及到的知识点介绍
2013/12/31 Javascript
Clipboard.js 无需Flash的JavaScript复制粘贴库
2015/10/02 Javascript
Vue全局分页组件的实现代码
2018/08/10 Javascript
JS中getElementsByClassName与classList兼容性问题解决方案分析
2019/08/07 Javascript
nginx部署多个vue项目的方法示例
2020/09/06 Javascript
ant design vue datepicker日期选择器中文化操作
2020/10/28 Javascript
[02:43]DOTA2英雄基础教程 半人马战行者
2014/01/13 DOTA
给你一面国旗 教你用python画中国国旗
2019/09/24 Python
python 列表、字典和集合的添加和删除操作
2019/12/16 Python
python Canny边缘检测算法的实现
2020/04/24 Python
Python下划线5种含义代码实例解析
2020/07/10 Python
Python Unittest原理及基本使用方法
2020/11/06 Python
html5 application cache遇到的严重问题
2012/12/26 HTML / CSS
荷兰皇家航空公司中国官网:KLM中国
2017/12/13 全球购物
澳大利亚礼品卡商店:Gift Card Store
2019/06/24 全球购物
计算机相关专业自荐信
2014/07/02 职场文书
教师查摆问题及整改措施
2014/10/11 职场文书
2016入党培训心得体会范文
2016/01/08 职场文书