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与element实现创建试卷相关功能(实例代码)
Dec 07 Vue.js
vue3使用vue-count-to组件的实现
Dec 25 Vue.js
Vue 简单实现前端权限控制的示例
Dec 25 Vue.js
Vue中ref和$refs的介绍以及使用方法示例
Jan 11 Vue.js
如何在vue 中使用柱状图 并自修改配置
Jan 21 Vue.js
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 Vue.js
vue使用lodop打印控件实现浏览器兼容打印的方法
Feb 07 Vue.js
基于vue的video播放器的实现示例
Feb 19 Vue.js
Vue-router编程式导航的两种实现代码
Mar 04 Vue.js
vue如何使用模拟的json数据查看效果
Mar 31 Vue.js
Vue OpenLayer 为地图绘制风场效果
Apr 24 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
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装最快的解决办法
2010/08/01 PHP
php获取通过http协议post提交过来xml数据及解析xml
2012/12/16 PHP
将word转化为swf 如同百度文库般阅读实现思路及代码
2013/08/09 PHP
Laravel使用memcached缓存对文章增删改查进行优化的方法
2016/10/08 PHP
PHP切割汉字的常用方法实例总结
2019/04/27 PHP
Javascript事件实例详解
2013/11/06 Javascript
javascript判断office版本示例
2014/04/11 Javascript
jQuery中map()方法用法实例
2015/01/06 Javascript
Angularjs全局变量被作用域监听的正确姿势
2016/02/06 Javascript
Seajs 简易文档 提供简单、极致的模块化开发体验
2016/04/13 Javascript
js中遍历Map对象的方法
2016/07/27 Javascript
Actionscript与javascript交互实例程序(修改)
2016/09/22 Javascript
AngularJS中directive指令使用之事件绑定与指令交互用法示例
2016/11/22 Javascript
微信小程序 两种滑动方式(横向滑动,竖向滑动)详细及实例代码
2017/01/13 Javascript
js实现简易聊天对话框
2017/08/17 Javascript
使用Vue.js和Flask来构建一个单页的App的示例
2018/03/21 Javascript
教你如何用node连接redis的示例代码
2018/07/12 Javascript
通过js给网页加上水印背景实例
2019/06/17 Javascript
js中script的上下放置区别,Dom的增删改创建操作实例分析
2019/12/16 Javascript
JS常见内存泄漏及解决方案解析
2020/05/30 Javascript
解决vue路由name同名,路由重复的问题
2020/08/05 Javascript
Python实现的简单hangman游戏实例
2015/06/28 Python
12步入门Python中的decorator装饰器使用方法
2016/06/20 Python
Python判断文件或文件夹是否存在的三种方法
2017/07/27 Python
Django实现全文检索的方法(支持中文)
2018/05/14 Python
django+echart数据动态显示的例子
2019/08/12 Python
基于Django实现日志记录报错信息
2019/12/17 Python
基于html5实现的图片墙效果
2014/10/16 HTML / CSS
Airbnb爱彼迎官网:成为爱彼迎房东,赚取收入
2019/03/14 全球购物
三个儿子教学反思
2014/02/03 职场文书
优秀求职信
2014/05/29 职场文书
家庭教育的心得体会
2014/09/01 职场文书
党员干部群众路线个人整改措施
2014/09/18 职场文书
学校机关党总支领导班子整改工作方案
2014/10/26 职场文书
python开发飞机大战游戏
2021/07/15 Python
MYSQL 表的全面总结
2021/11/11 MySQL