激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|

服務器之家 - 編程語言 - JAVA教程 - SpringMvc導出Excel實例代碼

SpringMvc導出Excel實例代碼

2020-07-23 12:02crossoverJie JAVA教程

本篇文章主要介紹了SpringMvc導出Excel實例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

相信很多朋友在實際工作中都會要將數據導出成Excel的需求,通常這樣的做法有兩種。

一是采用JXL來生成Excel,之后保存到服務器,然后在生成頁面之后下載該文件。

二是使用POI來生成Excel,之后使用Stream的方式輸出到前臺直接下載(ps:當然也可以生成到服務器中再下載。)。這里我們討論第二種。

Struts2的方式

通常我會將已經生成好的HSSFWorkbook放到一個InputStream中,然后再到xml配置文件中將返回結果更改為stream的方式。如下:

?
1
2
3
4
5
6
7
8
private void responseData(HSSFWorkbook wb) throws IOException {
  ByteArrayOutputStream baos = new ByteArrayOutputStream();
  wb.write(baos);
  baos.flush();
  byte[] aa = baos.toByteArray();
  excelStream = new ByteArrayInputStream(aa, 0, aa.length);
  baos.close();
}

配置文件:

?
1
2
3
4
5
6
7
<action name="exportXxx" class="xxxAction" method="exportXxx">
  <result name="exportSuccess" type="stream">
    <param name="inputName">excelStream</param>
    <param name="contentType">application/vnd.ms-excel</param>
    <param name="contentDisposition">attachment;filename="Undefined.xls"</param>
  </result>
</action>

這樣即可達到點擊鏈接即可直接下載文件的目的。

SpringMVC的方式

先貼代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@RequestMapping("/exportXxx.action")
public void exportXxx(HttpServletRequest request, HttpServletResponse response,
    @RequestParam(value="scheduleId", defaultValue="0")int scheduleId){
  HSSFWorkbook wb = createExcel(scheduleId) ;
  try {
    response.setHeader("Content-Disposition", "attachment; filename=appointmentUser.xls");
    response.setContentType("application/vnd.ms-excel; charset=utf-8") ;
    OutputStream out = response.getOutputStream() ;
    wb.write(out) ;
    out.flush();
    out.close();
  } catch (IOException e) {
    e.printStackTrace();
  }
}

其實springMVC和Struts2的原理上是一樣的,只是Struts2是才去配置文件的方式。首先是使用createExcel()這個方法來生成Excel并返回,最后利用response即可向前臺輸出Excel,這種方法是通用的,也可以試用與Servlet、Struts2等。我們只需要在response的頭信息中設置相應的輸出信息即可。

總結

不管是使用Struts2,還是使用SpringMVC究其根本都是使用的response,所以只要我們把response理解透了不管是下載圖片、world、Excel還是其他什么文件都是一樣的。

GitHub地址:https://github.com/crossoverJie

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://www.jianshu.com/p/9f57cb7ab6ae#

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本黄色一级视频 | 九色新网址 | 精品国产观看 | 久久艹艹艹 | 国产成人精品免费视频大全办公室 | 羞羞答答tv | 国产免费让你躁在线视频 | 亚洲涩涩图 | 欧美久久久一区二区三区 | 欧美黄色一区 | 男女生羞羞视频网站在线观看 | 精品一区在线视频 | 九九视频精品在线 | 在线观看免费av网 | 毛片118极品美女写真 | 欧美在线中文字幕 | 嗯~啊~弄嗯~啊h高潮视频 | 国产精品久久久久久久四虎电影 | 色婷婷一区二区三区 | 中文字幕在线亚洲精品 | 午夜精品视频免费观看 | 高清中文字幕在线 | 男女无套免费视频 | 成人免费毛片一 | 国产精品成人免费一区久久羞羞 | 99ri在线| 色婷婷久久久 | 日韩中文字幕一区二区三区 | 性欧美一区二区三区 | 国产精品免费久久久久久 | 成人福利视频在 | 国产一区二区三区高清 | 成人区一区二区三区 | 一区二区精品在线 | 羞羞草视频 | 国产精品久久久久久久模特 | 国产精品久久久久久久久久久久午夜 | 日韩av官网| 久草在线新视觉 | 综合色视频 | 欧洲成人综合网 |