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-例、title = "SpringMVC-ExcelFile-Example"、width = 640、height = 374

ソースコードをダウンロードする

ダウンロードする –

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の例]