前端實現(xiàn)獲取后端返回的文件流并下載三種方法
在前端開發(fā)中,有時需要從后端獲取文件流,并將其下載到本地。本文介紹如何在前端實現(xiàn)此功能的不同的實現(xiàn)方法,并分析其優(yōu)缺點
方法一:使用Axios實現(xiàn)文件流下載
使用Axios實現(xiàn)文件流下載的方法,本人親測可以實現(xiàn)
import axios from 'axios';
import { getToken } from '@/utils/auth'
handleExport() {
// 接口調(diào)用獲取文件
axios({
method: 'get',
responseType: 'blob', // 指定響應(yīng)類型為blob
url: this.GLOBAL.baseURL + '/api/v1/business/user/export',
data: this.queryParams, // 導(dǎo)入文件一般都用FormData格式數(shù)據(jù)
headers: { 'Authorization': 'Bearer ' + getToken() } // 傳遞token進行身份驗證
}).then(res => {
if (res.code === 200) {
// 導(dǎo)入成功
this.downloadBinaryFile(res.data, '導(dǎo)入失敗后下載的報錯文件')
} else {
// 輸出失敗信息
}
}).catch(error => {
console.error('下載失敗', error);
});
},
/**
* 將二進制文件下載到本地,保存為excel文件
* @param {*} binFile 二進制文件流
* @param {*} fileName 下載后的文件名
* @param {*} blobType 文件格式,默認為 "application/vnd.ms-excel"
*/
downloadBinaryFile(binFile, fileName, blobType = "application/vnd.ms-excel") {
// 創(chuàng)建 Blob 對象,包含二進制文件流和文件類型
const blobObj = new Blob([binFile], { type: blobType });
// 創(chuàng)建下載鏈接元素
const downloadLink = document.createElement('a');
// 處理不同瀏覽器的 URL 兼容性
let url = window.URL || window.webkitURL;
url = url.createObjectURL(blobObj); // 創(chuàng)建文件 URL
// 設(shè)置下載鏈接屬性
downloadLink.href = url;
downloadLink.download = fileName;
// 將下載鏈接添加到文檔中并觸發(fā)點擊事件
document.body.appendChild(downloadLink);
downloadLink.click();
// 移除下載鏈接并釋放 URL 對象
document.body.removeChild(downloadLink);
window.URL.revokeObjectURL(url);
}
實現(xiàn)的效果

優(yōu)點
- 支持傳遞Token進行身份驗證,安全性較高
- 支持POST請求,可以將參數(shù)放在請求體中,避免URL長度限制及參數(shù)暴露
缺點
- 實現(xiàn)相對復(fù)雜,需要手動創(chuàng)建和管理Blob對象及下載鏈接
方法二:使用封裝的Request工具實現(xiàn)文件流下載
接下來介紹使用封裝的Request工具實現(xiàn)文件流下載的方法
import request from '@/utils/request'
// 日志管理收藏、瀏覽、下載導(dǎo)出接口
export function exportUserOperateAdmin(data, headers) {
return request({
url: '/business/user/export',
method: 'get',
data: data,
headers: headers
})
}
// 調(diào)用導(dǎo)出接口
exportUserOperateAdmin(this.queryParams, { responseType: 'blob' }).then(
response => {
console.log(response)
const url = window.URL.createObjectURL(new Blob([response.data])) // 創(chuàng)建下載鏈接
const link = document.createElement('a')
link.href = url
link.download = '全文導(dǎo)入模板.xlsx' // 設(shè)置文件名
document.body.appendChild(link)
link.click() // 觸發(fā)下載
document.body.removeChild(link) // 下載后移除元素
}
).catch(error => {
console.error('下載失敗', error)
this.loading = false // 停止加載,隱藏加載狀態(tài)
})
優(yōu)點
- 封裝后的Request工具調(diào)用簡單,代碼更簡潔
- 支持傳遞Token進行身份驗證,安全性較高
缺點
- 實現(xiàn)相對簡單,但仍需手動處理Blob對象及下載鏈接
方法三:直接通過URL跳轉(zhuǎn)下載
最后介紹直接通過URL跳轉(zhuǎn)實現(xiàn)文件下載的方法
const baseurl = this.GLOBAL.baseURL // 拼接上導(dǎo)出的地址,如果接口還需要其他參數(shù),都可以直接拼接上 let url = baseurl + '/api/v1/business/user/export'; console.log(url) alert(url) // 第二個參數(shù)'_self'表示在當(dāng)前頁下載,不打開新的頁面 window.open(url, '_self')
優(yōu)點
- 實現(xiàn)簡單,不需要處理Blob對象及下載鏈接
- 適合下載無需身份驗證或參數(shù)簡單的文件
缺點
- 無法傳遞Token進行身份驗證,安全性較低
- 參數(shù)放在URL中不安全,且可能會導(dǎo)致URL過長
- 處理中文參數(shù)可能會出現(xiàn)亂碼問題
結(jié)論
以上三種方法各有優(yōu)缺點,實際開發(fā)中可以根據(jù)具體需求選擇合適的方法。
如果需要傳遞Token進行身份驗證并確保下載安全性,推薦使用方法一或方法二
如果只是簡單下載無需驗證的文件,可以考慮使用方法三
到此這篇關(guān)于前端實現(xiàn)獲取后端返回的文件流并下載三種方法的文章就介紹到這了,更多相關(guān)前端獲取后端返回文件流下載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談對于“不用setInterval,用setTimeout”的理解
這篇文章主要介紹了淺談對于“不用setInterval,用setTimeout”的理解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
javascript與CSS復(fù)習(xí)(《精通javascript》)
js和css結(jié)合來產(chǎn)生醒目的交互效果,我們可以快速的訪問元素自身的樣式屬性2010-06-06
JavaScript中l(wèi)ayim之整合右鍵菜單的示例代碼
這篇文章主要介紹了JavaScript中l(wèi)ayim之整合右鍵菜單的示例代碼,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02
詳解webpack 配合babel 將es6轉(zhuǎn)成es5 超簡單實例
本篇文章主要介紹了詳解webpack 配合babel 將es6轉(zhuǎn)成es5 超簡單實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
JavaScript 聯(lián)動的無限級封裝類,數(shù)據(jù)采用非Ajax方式,隨意添加聯(lián)動
JavaScript 聯(lián)動的無限級封裝類,數(shù)據(jù)采用非Ajax方式,隨意添加聯(lián)動2010-06-06
javascript 獲取radio的value的函數(shù) [已測]
javascript 獲取radio的value的函數(shù) 如果與asp,php等后臺語言結(jié)合時,一般用不到,但在純js環(huán)境下是必須的。2009-06-06

