国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

React獲取Java后臺(tái)文件流并下載Excel文件流程解析

瀏覽:114日期:2022-05-29 10:11:31

記錄使用blob對(duì)象接收java后臺(tái)文件流并下載為xlsx格式的詳細(xì)過(guò)程,關(guān)鍵部分代碼如下。

首先在java后臺(tái)中設(shè)置response中的參數(shù):

public void exportExcel(HttpServletResponse response, String fileName, String sheetName, List<String> titleRow, List<List<String>> dataRows) { OutputStream out = null; try { // 設(shè)置瀏覽器解析文件的mime類型,如果js中已設(shè)置,這里可以不設(shè)置 // response.setContentType('application/vnd.ms-excel;charset=gbk'); // 設(shè)置此項(xiàng),在IE瀏覽器中下載Excel文件時(shí)可彈窗展示文件下載 response.setHeader('Content-Disposition', 'attachment;filename=' + URLEncoder.encode(fileName, 'UTF-8')); // 允許瀏覽器訪問(wèn)header中的FileName response.setHeader('Access-Control-Expose-Headers', 'FileName'); // 設(shè)置FileName,轉(zhuǎn)碼防止中文亂碼 response.setHeader('FileName', URLEncoder.encode(fileName, 'UTF-8'));out = response.getOutputStream(); ExcelUtils.createExcelStream(out, sheetName, titleRow, dataRows); out.close(); } catch (Exception e) { if (Objects.nonNull(out)) { try {out.close(); } catch (IOException e1) {log.error('導(dǎo)出失敗', e); } } throw Exceptions.fail(ErrorMessage.errorMessage('500', '導(dǎo)出失敗')); }}

此時(shí)在瀏覽器的調(diào)試面板中可以看到導(dǎo)出接口的response header參數(shù)如下:

access-control-allow-credentials: trueaccess-control-allow-methods: GET,POST,PUT,DELETE,OPTIONSaccess-control-allow-origin: http://local.dasouche-inc.net:8081access-control-expose-headers: FileNameconnection: closecontent-type: application/vnd.ms-excel;charset=gbkdate: Sun, 29 Mar 2020 10:59:54 GMTfilename: %E4%B8%BB%E6%92%AD%E5%88%97%E8%A1%A8166296222340726.xlsx

接下來(lái)我們?cè)谇岸舜a中獲取文件流:

handleExport = () => { axios.post(`下載文件的接口請(qǐng)求路徑`, {}, { params: { 參數(shù)名1: 參數(shù)值1, 參數(shù)名2: 參數(shù)值2 }, // 設(shè)置responseType對(duì)象格式為blob responseType: 'blob' }).then(res => { // 創(chuàng)建下載的鏈接 const url = window.URL.createObjectURL(new Blob([res.data],// 設(shè)置該文件的mime類型,這里對(duì)應(yīng)的mime類型對(duì)應(yīng)為.xlsx格式{type: ’application/vnd.openxmlformats-officedocument.spreadsheetml.sheet’})); const link = document.createElement(’a’); link.href = url; // 從header中獲取服務(wù)端命名的文件名 const fileName = decodeURI(res.headers[’filename’]); link.setAttribute(’download’, fileName); document.body.appendChild(link); link.click(); });};

至此就可以愉快地下載xlsx格式的文件啦~

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: excel
相關(guān)文章:
主站蜘蛛池模板: 欧美激情免费观看一区 | 亚洲一区亚洲二区 | 欧美精品三区 | 亚洲视频 欧美视频 | 理论片我不卡在线观看 | 亚洲精品久久久久久久久久久网站 | 亚洲网站免费观看 | 久久riav.com| 最新国产区 | 欧美精品在欧美一区二区 | 国内美女福利视频在线观看网站 | 国产在线视频网址 | 国产精选一区二区 | 欧美色黄毛片 | 国产一区二区三区在线视频 | 91寡妇天天综合久久影院 | 国产美女视频做爰 | 中文字幕1区 | 成人禁在线观看网站 | 日本成人一级片 | 在线播放日韩 | 成人免费久久精品国产片久久影院 | 久久精品久久精品 | 国产日韩精品一区二区三区 | 美女黄视频在线观看 | 中文字幕或区 | 国内精品久久久久久久星辰影视 | 欧美一区精品二区三区 | 国产伦精一区二区三区 | 看日本真人一一级特黄毛片 | 人成18亚洲资源在线 | 一级女性全黄久久生活片 | 亚洲天堂久久精品成人 | 视频在线色| 国产精品一区二区久久精品涩爱 | 欧美成人视 | 100000免费啪啪18免进 | 国产三a级日本三级日产三级 | 亚洲精品亚洲人成在线 | 欧美高清性色生活 | 美国成人免费视频 |