Axios POST 下载文件;HTTP GET下载文件
2023-04-18 12:30:54 时间
1.遇到的问题
1)通过Post下载文件,发现服务网关(Kestrel)不允许添加响应头(未解决)
请求接口时候的配置:
exportSchemeDetail(param) {
return axios.postHeader('/you-api/', param, {
headers: {
'Content-Type': 'application/json-patch+json'
},
responseType: 'blob'
});
},
Axios修改(这里是转载的,忘记是谁写的了~):
axios.interceptors.response.use(
(response) => {
window.app.$insProgress.finish();
console.log(response.config)
if(response.config && response.config.responseType == 'blob') {
const blob = new Blob([response.data], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8' }); //application/vnd.openxmlformats-officedocument.spreadsheetml.sheet这里表示xlsx类型
console.log(response.headers['content-disposition'].split(';')[1])
let filename = decodeURI(response.headers['content-disposition'].split(';')[1].split('filename*=UTF-8''')[1]);
if ('download' in document.createElement('a')) {
const downloadElement = document.createElement('a');
let href = '';
if(window.URL) href = window.URL.createObjectURL(blob);
else href = window.webkitURL.createObjectURL(blob);
downloadElement.href = href;
downloadElement.download = filename;
document.body.appendChild(downloadElement);
downloadElement.click();
if(window.URL) window.URL.revokeObjectURL(href);
else window.webkitURL.revokeObjectURL(href);
document.body.removeChild(downloadElement);
console.log(href)
} else {
navigator.msSaveBlob(blob, filename);
}
return;
}
)}
2)通过Get下载文件,请求头参数过长,通过建立from表单提交,成功下载到文件
let pa = {'xx': JSON.stringify(param)}
for (var x in pa) {
var opt = document.createElement('textarea');
opt.name = x;
opt.value = pa[x];
temp_form .appendChild(opt);
}
document.body.appendChild(temp_form);
// 提交表单
temp_form.submit();
后台添加响应头(Get可以添加响应头,Post就不可以添加):
var fileName = HttpUtility.UrlEncode(string.Format("{0}_{1}", dowmFileName, DateTime.Now.ToString("yyyyMMddhhmmss")), System.Text.Encoding.UTF8);
Response.Headers.Add("Content-Disposition", string.Format("attachment; filename={0}.xls", fileName));
相关文章
- 【技术种草】cdn+轻量服务器+hugo=让博客“云原生”一下
- CLB运维&运营最佳实践 ---访问日志大洞察
- vnc方式登陆服务器
- 轻松学排序算法:眼睛直观感受几种常用排序算法
- 十二个经典的大数据项目
- 为什么使用 CDN 内容分发网络?
- 大数据——大数据默认端口号列表
- Weld 1.1.5.Final,JSR-299 的框架
- JavaFX 2012:彻底开源
- 提升as3程序性能的十大要点
- 通过凸面几何学进行独立于边际的在线多类学习
- 利用行动影响的规律性和部分已知的模型进行离线强化学习
- ModelLight:基于模型的交通信号控制的元强化学习
- 浅谈Visual Source Safe项目分支
- 基于先验知识的递归卡尔曼滤波的代理人联合状态和输入估计
- 结合网络结构和非线性恢复来提高声誉评估的性能
- 最佳实践丨云开发CloudBase多环境管理实践
- TimeVAE:用于生成多变量时间序列的变异自动编码器
- 具有线性阈值激活的神经网络:结构和算法
- 内网渗透之横向移动 -- 从域外向域内进行密码喷洒攻击