問題:當(dāng)axios發(fā)起post請求,后端返回的是二進制流excel文件,前臺獲取response時出現(xiàn)亂碼問題,求解決方法
response返回亂碼數(shù)據(jù)。
downloadModel(){
// window.location.href = window.open(axios.defaults.baseURL +'/settlement/payableCheck/download/template');
// let downLoadModel = window.open();
// let fileDownload = require('js-file-download');
this.$post('/settlement/payableCheck/download/template',{params:null},{responseType: 'arraybuffer'}).then(res => {
// this.$get('/settlement/payableCheck/download/template').then(res => {
console.log(res);
// let fileName = res.headers['content-disposition'].match(/fushun(\S*)xls/)[0];
// fileDownload(res,fileName);
let blob = new Blob([res], {type: "application/vnd.ms-excel;charset=utf-8"});
// let objectUrl = URL.createObjectURL(blob);
// window.location.href = objectUrl;
var link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = "對賬模板";
link.click();
}).catch((e) => {
this.$message.warning('下載失敗');
console.log(e);
})
},
強行text打開還是亂碼
最后一次更新:
既然樓主采納了我的答案,但有些問題,我還是要仔細說說,為此我寫了如下一段代碼,為了方便,我是直接下載一個存在在服務(wù)器根目錄下的xls。
axios.get('http://127.0.0.1/1.XLS', {
responseType: 'blob' //指定返回數(shù)據(jù)的格式為blob
})
.then(response => {
console.log(response);//把response打出來,看下圖
let url = window.URL.createObjectURL(response.data);
console.log(url)
var a = document.createElement("a");
document.body.appendChild(a);
a.href = url;
a.download = '2.xls';
a.click();
window.URL.revokeObjectURL(url);
})
.catch(err => {
console.log(`接口調(diào)用失敗`);
console.log(err);
})
這個圖可以明顯的看到,返回的response在的data 是一個blob Object
createObjectURL 函數(shù),接受的參數(shù)是blob 類型或者是File 類型
所以說,我想創(chuàng)建的URL 對象只需要 如下代碼
let url = window.URL.createObjectURL(response.data);
因為response.data 已經(jīng)是一個blob Object 了,完全不需要再像樓主在評論在回復(fù)我的解決方案中哪樣,用 let url = window.URL.createObjectURL(new Blob([res.data]))載入,哪為什么 這樣的代碼解決了樓主的問題呢,
個人猜想原因:
1.最有可能的原因,樓主請求的服務(wù)端,強制返回的就是二進制流,也就是說 responseType: 'blob' 根本沒有作用,因為設(shè)置responseType也需要服務(wù)端兼容的,并不是你指定什么,服務(wù)端就一定會按照你的指定來返加
2.樓主在axios設(shè)置了攔截器,修改了返回數(shù)據(jù),但這個可能性應(yīng)該不大
樓主修改問題后第一次編輯如下:
原回答如下:
responseType: 'arraybuffer' 改成 responseType: 'blob'
let objectUrl = URL.createObjectURL(res.data);
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團,成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。