AbstractExcelViewを使用したSpring MVCおよびExcelファイル
Spring MVCには
AbstractExcelView
クラスがあり、
Apache POI
ライブラリ経由でExcelファイルにデータをエクスポートします。このチュートリアルでは、Spring MVCアプリケーションで
AbstractExcelView
クラスを使用してデータをExcelファイルにダウンロードしてダウンロードする方法を示します。
1. Apache POI
Apache POIライブラリ
を入手してExcelファイルを作成します。
<!-- Excel library --> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.6</version> </dependency>
2.コントローラー
コントローラクラスは、デモ用のダミーデータを生成し、要求パラメータを取得してどのビューを返すかを決定します。要求パラメータが “EXCEL”に等しい場合は、Excelビュー(
AbstractExcelView
)を返します。
File:RevenueReportController.java
package com.mkyong.common.controller; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.bind.ServletRequestUtils; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.mvc.AbstractController; public class RevenueReportController extends AbstractController{ @Override protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response) throws Exception { String output = ServletRequestUtils.getStringParameter(request, "output"); //dummy data Map<String,String> revenueData = new HashMap<String,String>(); revenueData.put("Jan-2010", "$100,000,000"); revenueData.put("Feb-2010", "$110,000,000"); revenueData.put("Mar-2010", "$130,000,000"); revenueData.put("Apr-2010", "$140,000,000"); revenueData.put("May-2010", "$200,000,000"); if(output ==null || "".equals(output)){ //return normal view return new ModelAndView("RevenueSummary","revenueData",revenueData); }else if("EXCEL".equals(output.toUpperCase())){ //return excel view return new ModelAndView("ExcelRevenueSummary","revenueData",revenueData); }else{ //return normal view return new ModelAndView("RevenueSummary","revenueData",revenueData); } } }
3. AbstractExcelView
ファイル:Excel収入レポートView.java
package com.mkyong.common.view; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.springframework.web.servlet.view.document.AbstractExcelView; public class ExcelRevenueReportView extends AbstractExcelView{ @Override protected void buildExcelDocument(Map model, HSSFWorkbook workbook, HttpServletRequest request, HttpServletResponse response) throws Exception { Map<String,String> revenueData = (Map<String,String>) model.get("revenueData"); //create a wordsheet HSSFSheet sheet = workbook.createSheet("Revenue Report"); HSSFRow header = sheet.createRow(0); header.createCell(0).setCellValue("Month"); header.createCell(1).setCellValue("Revenue"); int rowNum = 1; for (Map.Entry<String, String> entry : revenueData.entrySet()) { //create the row data HSSFRow row = sheet.createRow(rowNum++); row.createCell(0).setCellValue(entry.getKey()); row.createCell(1).setCellValue(entry.getValue()); } } }
-
Note
+また、
JExcelAPI
を使用して同じExcelビューを作成する
AbstractJExcelView ** を使用することもできます。このリンクを参照してください://spring-mvc/spring-mvc-export-data-to- excel- file-via-abstractjexcelview/[AbstractJExcelViewの例]を参照してください。
4.春の設定
Excelビューの
XmlViewResolver
を作成します。
<beans ...> <bean class="org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping"/> <bean class="com.mkyong.common.controller.RevenueReportController"/> <bean class="org.springframework.web.servlet.view.XmlViewResolver"> <property name="location"> <value>/WEB-INF/spring-excel-views.xml</value> </property> </bean> </beans>
File:spring-excel-views.xml
<bean id="ExcelRevenueSummary" class="com.mkyong.common.view.ExcelRevenueReportView"> </bean>
5.デモ
ユーザーがダウンロードするためのExcelファイルを生成します。
ソースコードをダウンロードする
ダウンロードする –
SpringMVC-ExcelFile-AbstractExcelView-Example.zip
(9KB)
参考文献
Javadoc]。リンク://spring-mvc/spring-mvc-export-data-to-excel-file-as-abstractjexcelview/[Spring
MVCはAbstractJExcelViewを介してExcelファイルにデータをエクスポート]。リンク://spring-mvc/spring-mvc-xmlviewresolver-example/[Spring MVC
XmlViewResolverの例]