第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

為什么老師這里讀取excel文件要使用HSSFWorkBook,而沒有使用輸入流FileInputStream?我現(xiàn)在遇到一個(gè)bug,前端使用a標(biāo)簽進(jìn)行下載。a標(biāo)簽超鏈接指向后臺(tái)的下載接口。下載接口使用FileInputStream讀取項(xiàng)目下的excel文件。通過response.getOutputStream輸出流寫出文件。這樣的下載思路正確嗎?運(yùn)行結(jié)果是下載的excel文件打開內(nèi)容為空。這個(gè)問題在哪里?老師能指導(dǎo)一下嗎?

前端代碼:

<a?:href="'/api/campaign-api/coupon/down'"?download="down.xlsx">下載</a>

后端代碼:

1.接口

@ApiOperation(value?=?"下載")
@GetMapping("/down")
public?void?downTemplate(HttpServletResponse?response)?{
????String?fileName?=?"down.xlsx";
????couponService.down(response,?fileName);
}

2.實(shí)現(xiàn)類

public?void?down(HttpServletResponse?response?,String?filename)?{
????//?讀取要下載的文件,保存到文件輸入流
????FileInputStream?in?=?null;
????OutputStream?out?=?null;
????try?{
????????//?要下載的目標(biāo)文件
????????File?file?=?new?File("src\\main\\resources\\static"?+?"\\"?+?filename);
????????//?如果文件不存在
????????if?(!file.exists())?{
????????????throw?new?BusinessException("Could?not?read?file");
????????}
????????//?設(shè)置響應(yīng)頭,控制瀏覽器下載該文件
????????response.setHeader("Content-Disposition",?"attachment;filename="+filename);
????????response.setHeader("Content-Type",?"application/octet-stream;charset=UTF-8");
????????response.setContentType("application/octet-stream");
????????in?=?new?FileInputStream(file);
????????//?創(chuàng)建輸出流
????????out?=?response.getOutputStream();
????????//?創(chuàng)建緩沖區(qū)
????????byte?buffer[]?=?new?byte[1024];
????????int?len?=?0;
????????//?循環(huán)將輸入流中的內(nèi)容讀取到緩沖區(qū)當(dāng)中
????????while?((len?=?in.read(buffer))?>?0)?{
????????????//?輸出緩沖區(qū)的內(nèi)容到瀏覽器,實(shí)現(xiàn)文件下載
????????????out.write(buffer,?0,?len);
????????}
????????//?關(guān)閉文件輸入流
????????in.close();
????????//?關(guān)閉輸出流
????????out.close();
????}?catch?(Exception?e)?{
????????e.printStackTrace();
????}
}


正在回答

2 回答

正確流程:1.獲取到數(shù)據(jù) 2.解析到excle中 3.將解析的excel轉(zhuǎn)換成輸出流到前端,僅表示個(gè)人看法?

0 回復(fù) 有任何疑惑可以回復(fù)我~

沒看到對(duì)excel文件的操作,感覺你流程就不對(duì)?

0 回復(fù) 有任何疑惑可以回復(fù)我~
#1

qq_Coin_pyzcw

他這是下載,我看代碼里是讀取了對(duì)應(yīng)地址的文件的,因?yàn)檩斎肓魇嵌M(jìn)制的,所以直接os.flush()是沒問題的。
2021-03-03 回復(fù) 有任何疑惑可以回復(fù)我~

舉報(bào)

0/150
提交
取消

為什么老師這里讀取excel文件要使用HSSFWorkBook,而沒有使用輸入流FileInputStream?我現(xiàn)在遇到一個(gè)bug,前端使用a標(biāo)簽進(jìn)行下載。a標(biāo)簽超鏈接指向后臺(tái)的下載接口。下載接口使用FileInputStream讀取項(xiàng)目下的excel文件。通過response.getOutputStream輸出流寫出文件。這樣的下載思路正確嗎?運(yùn)行結(jié)果是下載的excel文件打開內(nèi)容為空。這個(gè)問題在哪里?老師能指導(dǎo)一下嗎?

我要回答 關(guān)注問題
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)