av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

springboot中Excel文件下載踩坑大全

瀏覽:135日期:2022-06-15 15:45:39
目錄項(xiàng)目場景:Spring boot文件下載問題一:下載的文件名稱出現(xiàn)中文亂碼的問題問題二:在swagger中測試下載接口,點(diǎn)擊下載的文件,發(fā)現(xiàn)文件名是亂碼的問題問題四:開發(fā)環(huán)境下載成功,打成jar包發(fā)布到服務(wù)器上部署就出現(xiàn)下載失敗問題完整代碼項(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ā)后,文件名亂碼問題:

springboot中Excel文件下載踩坑大全

解決方案:

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ù)。

springboot中Excel文件下載踩坑大全

springboot中Excel文件下載踩坑大全

解決辦法:給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)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: excel
相關(guān)文章:
主站蜘蛛池模板: 国产精品色综合 | 精品伊人久久 | 日韩欧美亚洲 | 黄色高清视频 | 国产一区二区三区四区三区四 | 草草网 | 亚洲va欧美va天堂v国产综合 | 天天躁人人躁人人躁狂躁 | 伊人精品| 国产无套一区二区三区久久 | www.五月天婷婷 | 久久久久久国产精品 | 欧美日韩一区二区在线 | 久久久亚洲一区 | 亚洲欧美一区在线 | 一区二区三区四区在线视频 | 国产探花在线精品一区二区 | 久久久爽爽爽美女图片 | 一区二区三区国产 | 国产小视频精品 | 国产中文字幕网 | a视频在线观看 | 91在线免费视频 | 国产成人99久久亚洲综合精品 | 亚洲国产成人av好男人在线观看 | 久草视频在线播放 | 粉色午夜视频 | 亚洲视频中文字幕 | 精品免费国产一区二区三区四区 | 6080亚洲精品一区二区 | 91中文在线观看 | h片在线免费看 | 亚洲网址在线观看 | 亚洲视频二| 999久久久 | 天天射天天干 | 成人久久18免费网站麻豆 | 91pron在线| 午夜av免费 | 国产一级片在线播放 | 久久精品国产99国产精品 |