vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常問題的解決

本文旨在解決vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常的問題,提供完整的代碼示例供參考。

一、分析問題

首先,需了解vue中下載文件的情況。一般情況下,我們都是使用http協議進行文件下載,但是當使用get請求時,瀏覽器默認會將文件後綴名加上.txt,導致下載下的文件無法正常打開。而使用post請求時則不會出現此問題。

二、解決方法

為了解決此問題,我們需要對下載文件的請求進行處理,強制讓瀏覽器以二進制方式打開文件。

1、前端代碼

// 綁定下載事件
async downloadFile(item) {
  const res = await axios({
    method: 'get',
    url: item.url,
    responseType: 'blob',
  });

  const fileName = decodeURI(res.headers['content-disposition'].split('=')[1]);
  const link = document.createElement('a');
  const blob = new Blob([res.data], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8' });

  link.href = URL.createObjectURL(blob);
  link.download = fileName;
  link.click();
},

2、後端代碼

@RequestMapping(value = "/download")
@ResponseBody
public ResponseEntity<ByteArrayResource> download(HttpServletRequest request, HttpServletResponse response) throws IOException {
  byte[] data = null;

  // 設置響應頭,通知瀏覽器以二進制流方式下載文件
  response.setContentType("application/octet-stream");
  response.setHeader("Content-Disposition", "attachment;filename=" + fileName);

  // 讀取文件
  File file = new File(filePath);
  FileInputStream input = new FileInputStream(file);
  data = new byte[(int) file.length()];
  input.read(data);
  input.close();

  return new ResponseEntity<ByteArrayResource>(new ByteArrayResource(data), HttpStatus.OK);
}

三、總結

以上就是解決vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常問題的解決方法。通過前後端的代碼處理,讓瀏覽器以二進制流方式打開下載的文件,再通過設置響應頭告訴瀏覽器以附件形式下載文件,就可以正常下載和打開文件了。

原創文章,作者:ASIMU,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/375603.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
ASIMU的頭像ASIMU
上一篇 2025-04-29 12:49
下一篇 2025-04-29 12:49

相關推薦

  • 如何在Java中拼接OBJ格式的文件並生成完整的圖像

    OBJ格式是一種用於表示3D對象的標準格式,通常由一組頂點、面和紋理映射坐標組成。在本文中,我們將討論如何將多個OBJ文件拼接在一起,生成一個完整的3D模型。 一、讀取OBJ文件 …

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • 為什麼用cmd運行Java時需要在文件內打開cmd為中心

    在Java開發中,我們經常會使用cmd在命令行窗口運行程序。然而,有時候我們會發現,在運行Java程序時,需要在文件內打開cmd為中心,這讓很多開發者感到疑惑,那麼,為什麼會出現這…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • Python zipfile解壓文件亂碼處理

    本文主要介紹如何在Python中使用zipfile進行文件解壓的處理,同時詳細討論在解壓文件時可能出現的亂碼問題的各種解決辦法。 一、zipfile解壓文件亂碼問題的根本原因 在P…

    編程 2025-04-29
  • Python將矩陣存為CSV文件

    CSV文件是一種通用的文件格式,在統計學和計算機科學中非常常見,一些數據分析工具如Microsoft Excel,Google Sheets等都支持讀取CSV文件。Python內置…

    編程 2025-04-29
  • Python如何導入py文件

    Python是一種開源的高級編程語言,因其易學易用和強大的生態系統而備受青睞。Python的import語句可以幫助用戶將一個模塊中的代碼導入到另一個模塊中,從而實現代碼的重用。本…

    編程 2025-04-29
  • Python合併多個相同表頭文件

    對於需要合併多個相同表頭文件的情況,我們可以使用Python來實現快速的合併。 一、讀取CSV文件 使用Python中的csv庫讀取CSV文件。 import csv with o…

    編程 2025-04-29
  • Python寫文件a

    Python語言是一種功能強大、易於學習、通用並且高級編程語言,它具有許多優點,其中之一就是能夠輕鬆地進行文件操作。文件操作在各種編程中都佔有重要的位置,Python作為開發人員常…

    編程 2025-04-29
  • Python分文件編寫

    Python分文件編寫是指將一個大型Python程序分割成多個文件,每個文件分別處理不同的任務。這樣,可以使代碼更加清晰、易於維護和理解。下面將從幾個方面來講解Python分文件編…

    編程 2025-04-29

發表回復

登錄後才能評論