Spring boot + Vue 文档下载

本文介绍了一个使用Vue.js实现的前端文件下载功能,通过Ajax发起POST请求到后端接口,后端通过流的方式将文件返回给前端进行下载。前端通过创建隐藏的a标签并触发点击事件实现自动下载,后端采用Java实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前端Vue代码:

downloadDocument (row) {
      let vm = this
      this.$ajax.post('/api/downloadDocument', row, {responseType: 'blob'})
        .then(function (res) {
          if (!res.data) {
            return
          }
          let url = window.URL.createObjectURL(new Blob([res.data]))
          let link = document.createElement('a')
          link.style.display = 'none'
          link.href = url
          link.setAttribute('download', row.fileName)

          document.body.appendChild(link)
          link.click()
        }
        ).catch(function (error) {
          let reader = new FileReader()
          reader.onload = function () {
            let jsonData = JSON.parse(this.result)
            vm.$message(jsonData.message)
          }
          reader.readAsText(error.response.data)
        })
    },

后端代码:

controller:

	@RequestMapping(value = "/downloadDocument", method = RequestMethod.POST)
	public void downloadDocument(@RequestBody DocumentDto documentDto, HttpServletResponse response)
			throws IOException {
		documentService.downloadDocument(documentDto, response.getOutputStream());
		response.flushBuffer();
	}

service:

	@Override
	public void downloadDocument(DocumentDto documentDto,  OutputStream os)  throws IOException {
		String fileName = documentDto.getFileName();
		Path documentPath = Paths.get(this.fileStorageLocation, documentDto.getFileFolderName()).toAbsolutePath()
				.normalize().resolve(fileName);
		org.apache.commons.io.FileUtils.copyFile(documentPath.toFile(), os);
	}

Good Luck,

Cheers!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值