欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端實現(xiàn)獲取后端返回的文件流并下載三種方法

 更新時間:2025年04月09日 09:27:36   作者:m0_74823524  
文件下載是最常見的流形式返回數(shù)據(jù)的應(yīng)用場景之一,通過流形式返回文件內(nèi)容,可以避免將整個文件加載到內(nèi)存中,從而減少內(nèi)存消耗,這篇文章主要介紹了前端實現(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)文章

最新評論