開発者ドキュメント

AbstractJExcelViewを介したSpring MVCとExcelファイル

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ファイルにデータをエクスポート]

モバイルバージョンを終了