请求获取对应的blob文件流

通过接口请求获取对应的blob文件流

后端代码

@RequestMapping({ "/dowfpath" })

public void downloadattch(@RequestParam("file_path") String file_path, HttpServletRequest request, HttpServletResponse response)

throws Exception {

response.setHeader("Pragma", "No-cache");

response.setHeader("Cache-Control", "no-cache");

response.setDateHeader("Expires", 0L);

// 查询文件信息

String path = "C:\\Users\\yhl\\Desktop\\SQ\\EPC\\EPC\\src\\main\\webapp\\resources\\img";

file_path = path+"\\1.jpg";

File file = new File(path);

// String[] list = file.list();

String filename = "1.jpg";

response.setContentType("application/x-download");

response.setHeader("Content-Disposition", "attachment; filename=\"" + filename + "\"");

// 查文件对象blob

ServletOutputStream outputStream = response.getOutputStream();

FileUtils.copyFile(new File(file_path), outputStream);

System.out.println(outputStream.toString());

}

前端代码

let fpath = json.resultlist[i].key;

let fname = json.resultlist[i].value;

var myurl=contxtpath+tablemodel+"/dowfpath.action?t="+new Date().getTime()+"&file_path="+fpath;

var params = {};

params.file_path=fpath;

var xhr = new XMLHttpRequest();

xhr.open('post', myurl)

xhr.setRequestHeader('Content-Type', 'application/json; charset=UTF-8') //我用了json

xhr.responseType = 'blob' //以blob的形式接收数据,一般文件内容比较大

xhr.onload = function() {

var content = this.response //Blob数据

var elink = document.createElement('a') // 创建一个a标签用于下载

elink.download = fname //规定被下载的超链接目标名字

elink.style.display = 'none' //标签隐藏

var blob = new Blob([content])

elink.href = URL.createObjectURL(blob) //规定链接指向的页面的URL

$(".gallerys").append(isGetImgDom(elink.href));

console.log(elink.href,blob.size,blob);

// elink.setAttribute("download",fname);

// document.body.appendChild(elink)

// elink.click() //原生dom触发

document.body.removeChild(elink)

}

xhr.send(JSON.stringify(params))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不想看海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值