亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java后端向前端返回文件流實(shí)現(xiàn)下載功能

 更新時(shí)間:2023年12月21日 14:34:30   作者:技術(shù)小羊  
后端可以使用Java中servlet提供的HttpServletResponse,核心步驟是要設(shè)置響應(yīng)的數(shù)據(jù)類型,設(shè)置為某一類文件類型或二進(jìn)制格式,以及響應(yīng)頭,然后用ServletOutputStream將文件以流的形式發(fā)送到前端,本文介紹Java后端向前端返回文件流實(shí)現(xiàn)下載功能,感興趣的朋友一起看看吧

前端實(shí)現(xiàn)文件下載功能有多種方法,這里就不一一介紹,這里只介紹使用文件流下載的實(shí)現(xiàn)方法。

既然是文件流那就肯定需要給前端返回一堆二進(jìn)制編碼,作為后端就可以返回一個(gè)OutPutStream

后端可以使用Java中servlet提供的HttpServletResponse,核心步驟是要設(shè)置響應(yīng)的數(shù)據(jù)類型,設(shè)置為某一類文件類型或二進(jìn)制格式,以及響應(yīng)頭,然后用ServletOutputStream將文件以流的形式發(fā)送到前端。

直接上代碼

response.setCharacterEncoding("UTF-8");
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition", "attachment;filename=example.xls");

解釋一下

  • 首先設(shè)置響應(yīng)數(shù)據(jù)類型,你要下載什么文件就設(shè)置什么類型,如果你不知道文件是什么類型但可以肯定他不是文本文件,那就用下面的application/octet-stream表示,這樣瀏覽器就知道這是一些二進(jìn)制數(shù)據(jù),就不會(huì)對(duì)其解析了。

  • 其次是設(shè)置響應(yīng)頭:

其次是設(shè)置響應(yīng)頭:

attachment: 表示響應(yīng)內(nèi)容應(yīng)該被當(dāng)作附件處理,會(huì)觸發(fā)瀏覽器下載行為。

filename:參數(shù)指定下載文件的名稱。上述代碼則會(huì)讓瀏覽器下載一個(gè)example.xls的文件。

這里給大家放一個(gè)鏈接,里面有常見的MIME類型,常見 MIME 類型列表 例如下圖,png類型,pdf,ppt等等。

然后就是用流的形式發(fā)送給前端

ServletOutputStream outputStream = response.getOutputStream();
checkInfo.write(outputStream);
outputStream.flush();

這樣后端就完成了把一個(gè)文件以文件流的形式傳遞給前端,前端發(fā)起請(qǐng)求就會(huì)觸發(fā)瀏覽器的下載行為。

下面是完整代碼

@GetMapping("/output/{classId}/{checkName}")
    public void checkToExcel(@PathVariable String checkName, @PathVariable String classId, HttpServletResponse response) {
        HSSFWorkbook checkInfo = checkExcelService.getCheckInfo(classId, checkName);
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("UTF-8");
        response.setHeader("Content-Disposition", "attachment;filename=" + checkName + "簽到統(tǒng)計(jì)表.xls");
        try {
            ServletOutputStream outputStream = response.getOutputStream();
            checkInfo.write(outputStream);
            outputStream.flush();
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }

不知道有沒有朋友像我一樣,方法的返回值寫的是流(例如ByteArrayOutputStream)這么寫就錯(cuò)了

我之前在寫這個(gè)程序時(shí)就是向前端返回一個(gè)流,結(jié)果下載的文件始終格式錯(cuò)誤,瀏覽器收到的響應(yīng)數(shù)據(jù)類型也一直是json,原因就在于沒有使用response發(fā)送流,所以一定要使用response.getOutputStream()獲取流,然后再去flush,這樣前端才真正收到的是二進(jìn)制文件流。

到此這篇關(guān)于Java后端向前端返回文件流——實(shí)現(xiàn)下載功能!的文章就介紹到這了,更多相關(guān)Java后端向前端返回文件流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java中對(duì)HashMap的put過程解讀

    java中對(duì)HashMap的put過程解讀

    這篇文章主要介紹了java中對(duì)HashMap的put過程解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • MybatisPlus實(shí)現(xiàn)邏輯刪除功能

    MybatisPlus實(shí)現(xiàn)邏輯刪除功能

    這篇文章主要介紹了MybatisPlus實(shí)現(xiàn)邏輯刪除功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Java導(dǎo)出oracle表結(jié)構(gòu)實(shí)例詳解

    Java導(dǎo)出oracle表結(jié)構(gòu)實(shí)例詳解

    這篇文章主要介紹了 Java導(dǎo)出oracle表結(jié)構(gòu)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • Java中調(diào)用第三方接口的詳細(xì)代碼示例

    Java中調(diào)用第三方接口的詳細(xì)代碼示例

    這篇文章主要介紹了Java中調(diào)用第三方接口的詳細(xì)代碼示例,文章總結(jié)了多種Java進(jìn)行HTTP請(qǐng)求的方法,每種方法都有其特點(diǎn)和適用場景,從原生到封裝,再到聲明式客戶端,滿足了不同復(fù)雜度的HTTP請(qǐng)求需求,需要的朋友可以參考下
    2024-12-12
  • spring boot 如何指定profile啟動(dòng)

    spring boot 如何指定profile啟動(dòng)

    這篇文章主要介紹了spring boot 如何指定profile啟動(dòng)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • java中continue和break區(qū)別詳細(xì)解析

    java中continue和break區(qū)別詳細(xì)解析

    break和continue都是跳轉(zhuǎn)語句,它們將程序的控制權(quán)轉(zhuǎn)移到程序的另一部分,下面這篇文章主要給大家介紹了關(guān)于java中continue和break區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • Java使用Deque實(shí)現(xiàn)堆棧的方法

    Java使用Deque實(shí)現(xiàn)堆棧的方法

    這篇文章主要介紹了Java使用Deque實(shí)現(xiàn)堆棧的方法,實(shí)例分析了java簡單實(shí)現(xiàn)堆棧的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • 詳解MySQL事務(wù)日志undo log

    詳解MySQL事務(wù)日志undo log

    眾所周知,事務(wù)的一大特點(diǎn)是原子性,即同一事務(wù)的SQL要同時(shí)成功或者失敗,那大家有沒有想過在MySQL的innoDB存儲(chǔ)引擎中是如何保證這樣的原子性操作的,接下來就帶大家一探究竟,感興趣的小伙伴和小編一起來探討吧
    2023-07-07
  • mybatis查詢語句揭秘之封裝數(shù)據(jù)

    mybatis查詢語句揭秘之封裝數(shù)據(jù)

    這篇文章主要給大家介紹了關(guān)于mybatis查詢語句揭秘之封裝數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mybatis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 詳解Java中對(duì)象序列化與反序列化

    詳解Java中對(duì)象序列化與反序列化

    這篇文章主要為大家詳細(xì)介紹了Java中對(duì)象序列化與反序列化,感興趣的小伙伴們可以參考一下
    2016-02-02

最新評(píng)論