Ajax下載文件流詳解

一、Ajax簡介

Ajax,全稱為Asynchronous JavaScript and XML,即異步JavaScript和XML技術,是一種無需刷新整個頁面的技術。Ajax可以局部更新頁面,提高用戶的交互性,提高Web應用的速度和流暢度。

在Ajax技術中,瀏覽器通過Javascript向服務器發出異步請求,服務器返回數據後,由Javascript動態更新網頁內容,不需要重新加載整個網頁,可以讓用戶體驗更加流暢。

二、Ajax下載文件流原理

Ajax下載文件的原理跟普通的文件下載不同。一般下載文件都是通過鏈接下載文件觸發瀏覽器的下載功能,然後由瀏覽器接管下載任務,直接將文件下載到本地硬盤中。

而ajax下載文件採用的是XMLHttpRequest對象實現。當我們通過Ajax下載文件時,服務器將文件流寫到後台的輸出流中,這個輸出流會被封裝成一個ajax響應直接返回客戶端。Ajax會通過XMLHttpRequest獲取文件流,這個流會被JavaScript解析,我們可以自己定義文件名和類型,然後通過a標籤的download屬性進行文件下載。

三、實現Ajax下載文件流

(1)服務器端代碼

在服務器端,我們可以通過Java或其他語言編寫Controller層代碼,用於向客戶端響應文件流。以下是Java Spring MVC框架的代碼片段示例。

    
        /**
         * @param request
         * @param response
         * @return void
         * @Description: Ajax下載文件
         */
        @RequestMapping(value = "/downloadfile", method = RequestMethod.POST)
        public void downloadFile(HttpServletRequest request, HttpServletResponse response) {
            try {
                String fileName = "test.xlsx";
                response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
                //attachment;以附件方式下載
                response.setHeader("Content-Disposition", "attachment;fileName=" + new String(fileName.getBytes(), "iso-8859-1"));

                InputStream inputStream = new FileInputStream(new File("D:\\test.xlsx"));
                byte[] buff = new byte[1024];
                OutputStream os = response.getOutputStream();
                int i = 0;
                while ((i = inputStream.read(buff)) != -1) {
                    os.write(buff, 0, i);
                    os.flush();
                }
                os.close();
                inputStream.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    

(2)前端代碼

前端代碼中主要是通過XMLHttpRequest對象請求後台action,然後獲取響應的數據流來實現ajax文件下載。以下是前端代碼的示例。

    
        function download(id) {
            // XMLHttpRequest對象用於在後台與服務器交換數據
            var xhr = new XMLHttpRequest();
            var fileId = id;
            var filename = '文件名稱.xlsx';
            //定製返回的內容
            xhr.overrideMimeType('text/plain; charset=x-user-defined-binary');
            xhr.onreadystatechange = function(){
                // readyState == 4說明請求已完成
                if(xhr.readyState == 4 && xhr.status == 200){
                    // 獲取響應的二進制流
                    var responseText = xhr.responseText;
                    // 把二進制流轉化為blob對象
                    var blob = new Blob([responseText]);
                    // 指定文件的下載類型
                    var type = blob.type || 'application/octet-stream';
                    // 獲取下載文件的地址,並指定下載文件名  
                    var URL = window.URL || window.webkitURL;
                    var downloadUrl = URL.createObjectURL(blob);
                    // 創建一個下載鏈接  
                    var link = document.createElement('a');
                    link.href = downloadUrl;
                    link.download = filename;
                    var event = document.createEvent('MouseEvents');
                    event.initMouseEvent('click', true, true, window, 1, 0, 0, 0, 0, false, false, false, false, 0, null);
                    link.dispatchEvent(event);
                }
            }
            // 發送http請求  
            xhr.open('POST', '/downloadfile', true);
            xhr.responseType = "arraybuffer";
            xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
            var requestParams = "fileid="+fileId;
            xhr.send(requestParams);
        }
    

(3)頁面代碼

最後是頁面代碼。我們可以通過一個按鈕或其他元素來觸發下載文件的操作。

    
        
    

四、Ajax下載文件流的注意事項

在實現Ajax下載文件流時,需要注意以下幾點:

1. 服務器端需要設置文件下載的HTTP頭信息,通過Content-Disposition設置下載的文件名和文件格式。

2. 前端需要通過XMLHttpRequest獲取文件流,並且將返回的二進制流轉為blob對象。

3. 在下載文件之前需要通過創建下載鏈接指定下載文件名和文件類型。

4. 瀏覽器的下載功能由URL.createObjectURLMouseEvent兩個API實現。

五、總結

通過以上的步驟,我們可以輕鬆實現Ajax下載文件流的功能。對於需要下載大文件或者需要處理下載文件之後的操作的情況,使用Ajax下載文件流可以提高用戶體驗和Web應用的性能。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/188376.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-28 13:30
下一篇 2024-11-28 13:30

相關推薦

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

    本文旨在解決vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常的問題,提供完整的代碼示例供參考。 一、分析問題 首先,需了解vue中下載文件的情況。一般情況下,我們…

    編程 2025-04-29
  • 如何在Java中拼接OBJ格式的文件並生成完整的圖像

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

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

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

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

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

    編程 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

發表回復

登錄後才能評論