后台传文件流给我,我要怎么下载 post获取的文件流是不是不能通过window.location.href下载?如果能下载该怎么处理,这种情况下前端location.href好像不能下载。如果是get的话是不是location.href就能下载?
后台传文件流给我,我要怎么下载 post获取的文件流是不是不能通过window.location.href下载?如果能下载该怎么处理,这种情况下前端location.href好像不能下载。如果是get的话是不是location.href就能下载?
我们项目中使用的。
export const downloadFile = (fileName, url) => {
if (isIE()) {
ieDown(url)
} else {
const aLink = document.createElement('a');
const evt = document.createEvent('MouseEvents');
// var evt = document.createEvent("HTMLEvents")
evt.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
aLink.download = fileName;
aLink.href = url;
aLink.dispatchEvent(evt)
}
};
const ieDown = url => {
window.open(url)
};
const isIE = () => {
const explorer = window.navigator.userAgent;
return explorer.indexOf('MSIE') >= 0 || explorer.indexOf('Trident/7.0') >= 0 || explorer.indexOf('Edge') >= 0;
};
两种方法(第二种貌似是后端加)
1.<a href="你的下载地址" download>
核心是download属性。
2.下载地址加header("Content-Disposition:attachment;filename=xxx");
核心是header。
10 回答11.2k 阅读
5 回答4.9k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.8k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
3 回答2.2k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
后来解决了,但是不知道为什么文件名是797bb297-60ea-4069-911b-04133ce2b313这种类型
后台的人是设置了Content-Disposition,前端是是使用了vue和vueResource,vueResource在请求的时候需要加一句
Vue.http.options.responseType = 'arraybuffer'
,然后再对返回的数据流做如下处理