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 基于abstract 路由模式 实现页面内嵌的示例代码
Dec 14 Vue.js
Vue中computed和watch有哪些区别
Dec 19 Vue.js
Vue实现摇一摇功能(兼容ios13.3以上)
Jan 26 Vue.js
vue集成一个支持图片缩放拖拽的富文本编辑器
Jan 29 Vue.js
Vue 实例中使用$refs的注意事项
Jan 29 Vue.js
vue浏览器返回监听的具体步骤
Feb 03 Vue.js
vue-router懒加载的3种方式汇总
Feb 28 Vue.js
vue3.0中使用element的完整步骤
Mar 04 Vue.js
Vue全家桶入门基础教程
May 14 Vue.js
springboot+VUE实现登录注册
May 27 Vue.js
一起来看看Vue的核心原理剖析
Mar 24 Vue.js
Vue组件更新数据v-model不生效的解决
Apr 02 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
常用参考资料(手册)下载或者链接
2006/07/22 Javascript
走出JavaScript初学困境—js初学
2008/12/29 Javascript
JS中如何设置readOnly的值
2013/12/25 Javascript
禁用页面部分JavaScript不是全部而是部分
2014/09/03 Javascript
jQuery实现视频作为全屏幕背景
2014/12/18 Javascript
JavaScript实现随机替换图片的方法
2015/04/16 Javascript
jQuery基于ajax实现带动画效果无刷新柱状图投票代码
2015/08/10 Javascript
微信小程序 Video API实例详解
2016/10/02 Javascript
angular2倒计时组件使用详解
2017/01/12 Javascript
bootstrap-table.js扩展分页工具栏(增加跳转到xx页)功能
2017/12/28 Javascript
element-ui 限制日期选择的方法(datepicker)
2018/05/16 Javascript
详解koa2学习中使用 async 、await、promise解决异步的问题
2018/11/13 Javascript
js变量声明var使用与不使用的区别详解
2019/01/21 Javascript
vue基础之事件v-onclick="函数"用法示例
2019/03/11 Javascript
Vuex新手的理解与使用详解
2019/05/31 Javascript
Vue中实现权限控制的方法示例
2019/06/07 Javascript
微信小程序 自定义复选框实现代码实例
2019/09/04 Javascript
VUE项目axios请求头更改Content-Type操作
2020/07/24 Javascript
Python正则简单实例分析
2017/03/21 Python
怎么使用pipenv管理你的python项目
2018/03/12 Python
Python实现基于PIL和tesseract的验证码识别功能示例
2018/07/11 Python
使用Python处理BAM的方法
2018/09/28 Python
python实现图片九宫格分割
2021/03/07 Python
python实现简单坦克大战
2020/03/27 Python
利用python绘制数据曲线图的实现
2020/04/09 Python
python golang中grpc 使用示例代码详解
2020/06/03 Python
CSS3实现闪烁动画效果的方法
2015/02/09 HTML / CSS
Snapfish爱尔兰:在线照片打印和个性化照片礼品
2018/09/17 全球购物
英国二手iPhone、音乐、电影和游戏商店:musicMagpie
2018/10/26 全球购物
《争吵》教学反思
2014/02/15 职场文书
小学生教师节演讲稿
2014/09/03 职场文书
大学生党性分析材料
2014/12/19 职场文书
大学生读书笔记范文
2015/07/01 职场文书
2015年法律事务部工作总结
2015/07/27 职场文书
如何用threejs实现实时多边形折射
2021/05/07 Javascript
python必学知识之文件操作(建议收藏)
2021/05/30 Python