时间:2021-05-26
前台请求数据:
url: '/app/downloadApp', method: 'get', responseType: 'blob', params: data设置接收参数格式为responseType: ‘blob',
downloadFile(res, fileName) { if (!res) { return } if (window.navigator.msSaveBlob) { // IE以及IE内核的浏览器 try { window.navigator.msSaveBlob(res, fileName) // res为接口返回数据,这里请求的时候已经处理了,如果没处理需要在此之前自行处理var data = new Blob([res.data]) 注意这里需要是数组形式的,fileName就是下载之后的文件名 // window.navigator.msSaveOrOpenBlob(res, fileName); //此方法类似上面的方法,区别可自行百度 } catch (e) { console.log(e) } } else { let url = window.URL.createObjectURL(new Blob([res])) let link = document.createElement('a') link.style.display = 'none' link.href = url link.setAttribute('download', fileName)// 文件名 document.body.appendChild(link) link.click() document.body.removeChild(link) // 下载完成移除元素 window.URL.revokeObjectURL(url) // 释放掉blob对象 } }, download(){ var data = { appId:this.appId } downloadAppAjax(data).then(res => { const filename = decodeURI(res.headers['content-disposition'].split(';')[1].split('=')[1]); console.log(filename) this.downloadFile(res.data,filename) }) }这里的downloadAppAjax调用后台接口,请求数据,获取后台返回的数据没有文件名,最后发现在header Content-Disposition属性里 attachment;filename=app.jpg
所以我们要实现下载自动重命名就需要拿出filename,这里我们使用decodeURI对Content-Disposition属性值进行解码,拿到filename:
decodeURI(res.headers['content-disposition'].split(';')[1].split('=')[1]);
拿到文件流和文件名后 接收文件流并创建地址
let url =window.URL.createObjectURL(new Blob([res]))
接着利用a标签进行下载即可。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
引言批量下载思路,首先前端发送下载请求,携带必要参数,也可无参默认批量下载页面全部数据;后台接收后进行数据处理拿到要下载文件的下载地址,循环下载地址,用压缩流,
本文实例为大家分享了java实现文件上传下载的具体代码,供大家参考,具体内容如下一.上传1.前端: 2.后台:importjava.io.File;i
我就废话不多说了,大家还是直接看代码吧~前端项目下载导出文件/***post方式*返回:文件流*好处:可以自己修改文件名称方便调试*/letparams={Li
在修改数据时,需要先加载数据。在加载combobox数据的时候,从后台传来的应该int类型的数据。html代码复制代码代码如下:院系:javascript代码复
Angular/VueHTTPPOST下载流文件HTTPPOST请求流文件转成excel在使用Angular开发项目时,通常会有下载文件的功能项。一般是后台返回