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

springboot中Excel文件下載踩坑大全

 更新時間:2021年07月08日 15:05:35   作者:斗者_(dá)2013  
本文主要介紹了springboot中Excel文件下載,但是卻容易遇到很多坑,文中通過示例代碼介紹的非常詳細(xì),感興趣的小伙伴們可以參考一下

項(xiàng)目場景:Spring boot文件下載

調(diào)用接口下載spring boot工程的resources目錄下的excel模板文件,非常常見的一個文件下載功能,但是卻容易遇到很多坑,下面總結(jié)記錄下。

問題一:下載的文件名稱出現(xiàn)中文亂碼的問題

解決方案:

response.setHeader("Content-Disposition",
                "attachment;filename=" + new String("下載模板".getBytes("UTF-8"), "ISO8859-1"));

說明:
這是網(wǎng)上最常見的解決方案,經(jīng)過這樣的修改后,在瀏覽器上調(diào)用get請求下載的文件確實(shí)沒有出現(xiàn)文件名中文亂碼了。
但是在swagger里面測試接口,下載的問題還是會出現(xiàn)中文亂碼。

問題二:在swagger中測試下載接口,點(diǎn)擊下載的文件,發(fā)現(xiàn)文件名是亂碼的問題

這里我項(xiàng)目中使用的是springdoc-openapi-ui 1.5.9,基于的是openapi3.0的協(xié)議。
整體使用方式和界面和swagger類似。

swagger中下載的文件,點(diǎn)擊開發(fā)后,文件名亂碼問題:

在這里插入圖片描述

解決方案:

response.setHeader("Content-Disposition", "attachment;fileName=" + 
URLEncoder.encode("線索導(dǎo)入模板.xlsx","utf8"));

說明:
通過URLEncoder.encode函數(shù)對文件名稱處理后,無論是在瀏覽器調(diào)用GET請求下載文件,還是Swagger中調(diào)用下載接口,都不會出現(xiàn)文件名亂碼問題。

問題三:下載的excel文件打開時總是提示部分內(nèi)容有問題,嘗試恢復(fù)。

在這里插入圖片描述

在這里插入圖片描述

解決辦法:
給response的Header設(shè)置大?。?/p>

/加上設(shè)置大小 下載下來的excel文件才不會在打開前提示修復(fù)
response.addHeader("Content-Length",String.valueOf(file.length()));

問題四:開發(fā)環(huán)境下載成功,打成jar包發(fā)布到服務(wù)器上部署就出現(xiàn)下載失敗問題

原因:
Resource下的文件是存在于jar這個文件里面,在磁盤上是沒有真實(shí)路徑存在的,它其實(shí)是位于jar內(nèi)部的一個路徑。所以通過ResourceUtils.getFile或者this.getClass().getResource("")方法無法正確獲取文件。

解決:
通過ClassPathResource讀取文件流

 ClassPathResource classPathResource = new ClassPathResource("template/template.xlsx");

完整代碼

1、控制層代碼

@Operation(summary = "下載模版",description = "下載模版")
@GetMapping("/download")
public void download(HttpServletResponse response){
    templateService.download(response);
}

2、下載方法實(shí)現(xiàn)

/**
 * 下載線索模板
 * @param response
 */
public void download(HttpServletResponse response) {
    InputStream inputStream = null;
    BufferedInputStream bis = null;
    OutputStream outputStream = null;
    try {
        ClassPathResource classPathResource = new ClassPathResource("template/template.xlsx");
        inputStream = classPathResource.getInputStream();

        response.setContentType("application/octet-stream");
        response.setHeader("content-type", "application/octet-stream");
        //待下載文件名
        String fileName = URLEncoder.encode("模板.xlsx","utf8");
        response.setHeader("Content-Disposition", "attachment;fileName=" + fileName);
        //加上設(shè)置大小 下載下來的excel文件才不會在打開前提示修復(fù)
        response.addHeader("Content-Length",String.valueOf(classPathResource.getFile().length()));

        byte[] buff = new byte[1024];
        outputStream = response.getOutputStream();
        bis = new BufferedInputStream(inputStream);
        int read = bis.read(buff);
        while (read != -1) {
            outputStream.write(buff, 0, buff.length);
            outputStream.flush();
            read = bis.read(buff);
        }
    } catch ( IOException e ) {
        log.error("文件下載失敗,e");
    } finally {
        IOUtils.closeQuietly(outputStream);
        IOUtils.closeQuietly(inputStream);
        IOUtils.closeQuietly(bis);
    }
}

參考:https://blog.csdn.net/Hi_Boy_/article/details/107198371

到此這篇關(guān)于springboot中Excel文件下載踩坑大全的文章就介紹到這了,更多相關(guān)springboot Excel文件下載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SPRING FRAMEWORK BEAN作用域和生命周期原理解析

    SPRING FRAMEWORK BEAN作用域和生命周期原理解析

    這篇文章主要介紹了SPRING FRAMEWORK BEAN作用域和生命周期原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • idea?maven?經(jīng)常主目錄自動變回默認(rèn)的解決方法

    idea?maven?經(jīng)常主目錄自動變回默認(rèn)的解決方法

    很多朋友反映idea?maven?經(jīng)常主目錄自動變回默認(rèn),遇到這樣的問題真的很頭疼,該如何解決呢?下面小編給大家介紹下idea?maven目錄變回默認(rèn)的解決方法,需要的朋友可以參考下
    2022-08-08
  • idea中自動生成Java類圖和時序圖的圖文教程

    idea中自動生成Java類圖和時序圖的圖文教程

    本文主要介紹了idea中自動生成Java類圖和時序圖的圖文教程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • java fastdfs客戶端使用實(shí)例代碼

    java fastdfs客戶端使用實(shí)例代碼

    這篇文章主要介紹了java fastdfs客戶端使用實(shí)例代碼,簡單介紹了FastDFS的概念和架構(gòu),然后分享了實(shí)例代碼,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Spring?Data?JPA關(guān)系映射@OneToOne實(shí)例解析

    Spring?Data?JPA關(guān)系映射@OneToOne實(shí)例解析

    這篇文章主要為大家介紹了Spring?Data?JPA關(guān)系映射@OneToOne實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • mybatis框架order by作為參數(shù)傳入時失效的解決

    mybatis框架order by作為參數(shù)傳入時失效的解決

    這篇文章主要介紹了mybatis框架order by作為參數(shù)傳入時失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 淺析JDBC的使用方法

    淺析JDBC的使用方法

    這篇文章主要介紹了JDBC的使用方法,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下
    2020-08-08
  • 如何利用Spring的@Import擴(kuò)展點(diǎn)與spring進(jìn)行無縫整合

    如何利用Spring的@Import擴(kuò)展點(diǎn)與spring進(jìn)行無縫整合

    這篇文章主要介紹了如何利用Spring的@Import擴(kuò)展點(diǎn)與spring進(jìn)行無縫整合的實(shí)例代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • 詳解Spring Cloud Stream使用延遲消息實(shí)現(xiàn)定時任務(wù)(RabbitMQ)

    詳解Spring Cloud Stream使用延遲消息實(shí)現(xiàn)定時任務(wù)(RabbitMQ)

    這篇文章主要介紹了詳解Spring Cloud Stream使用延遲消息實(shí)現(xiàn)定時任務(wù)(RabbitMQ),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Mybatis的入門示例代碼

    Mybatis的入門示例代碼

    首先新建一個JavaWeb項(xiàng)目并導(dǎo)入mybatis依賴的jar包,同時Mybatis是對數(shù)據(jù)庫的操作所以我們需要在數(shù)據(jù)庫中新建一個表user用來演示。下面通過本文給大家詳細(xì)介紹Mybatis的入門示例代碼,感興趣的朋友一起看看吧
    2016-11-11

最新評論