Spring MVCには、
JExcelAPI
ライブラリ経由でExcelファイルにデータをエクスポートする
AbstractJExcelView
クラスが付属しています。このチュートリアルでは、Spring MVCアプリケーションで
AbstractJExcelView
クラスを使用してデータをExcelファイルにダウンロードしてダウンロードする方法を示します。
1. JExcelAPI
JExcelAPI library
を入手してください。
<!-- JExcelAPI library -->
<dependency>
<groupId>net.sourceforge.jexcelapi</groupId>
<artifactId>jxl</artifactId>
<version>2.6.3</version>
</dependency>
2.コントローラー
コントローラクラスは、デモ用のダミーデータを生成し、要求パラメータを取得してどのビューを返すかを決定します。要求パラメータが “EXCEL”に等しい場合は、Excelビュー(
AbstractJExcelView
)を返します。
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. AbstractJExcelView
File:ExcelRevenueReportView.java
package com.mkyong.common.view;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import org.springframework.web.servlet.view.document.AbstractJExcelView;
public class ExcelRevenueReportView extends AbstractJExcelView{
@Override
protected void buildExcelDocument(Map model, WritableWorkbook workbook,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
Map<String,String> revenueData = (Map<String,String>) model.get("revenueData");
WritableSheet sheet = workbook.createSheet("Revenue Report", 0);
sheet.addCell(new Label(0, 0, "Month"));
sheet.addCell(new Label(1, 0, "Revenue"));
int rowNum = 1;
for (Map.Entry<String, String> entry : revenueData.entrySet()) {
//create the row data
sheet.addCell(new Label(0, rowNum, entry.getKey()));
sheet.addCell(new Label(1, rowNum, entry.getValue()));
rowNum++;
}
}
}
-
Note
Apache POI
APIを使用して
AbstractExcelView ** を使用して同じExcelビューを作成することもできます。このリンクを参照してください://spring-mvc/spring-mvc-export-data-to-excel -file-by-abstractexcelview/[AbstractExcelViewの例]をクリックします。
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
<beans ...">
<bean id="ExcelRevenueSummary"
class="com.mkyong.common.view.ExcelRevenueReportView">
</bean>
</beans>
5.デモ
ユーザーがダウンロードするためのExcelファイルを生成します。
ソースコードをダウンロードする
ダウンロードする – リンク://wp-content/uploads/2010/08/SpringMVC-ExcelFile-AbstractJExcelView-Example.zip[SpringMVC-ExcelFile-AbstractJExcelView-Example.zip](9KB)
参考文献
Javadoc]。リンク://spring-mvc/spring-mvc-export-data-to-excel-file-by-abstractexcelview/[Spring
MVCはAbstractExcelViewを介してExcelファイルにデータをエクスポート]