Spring MVC- und Excel-Datei über AbstractJExcelView

Spring MVC- und Excel-Datei über AbstractJExcelView

Spring MVC wird mit der KlasseAbstractJExcelViewgeliefert, um Daten über die BibliothekJExcelAPIin eine Excel-Datei zu exportieren. In diesem Lernprogramm wird die Verwendung der KlasseAbstractJExcelViewin der Spring MVC-Anwendung zum Exportieren von Daten in eine Excel-Datei zum Herunterladen gezeigt.

1. JExcelAPI

Holen Sie sich dieJExcelAPI library.

    
    
    net.sourceforge.jexcelapi
    jxl
    2.6.3
    

2. Regler

Eine Controller-Klasse, generiert Dummy-Daten zur Demonstration und ruft den Anforderungsparameter ab, um zu bestimmen, welche Ansicht zurückgegeben werden soll. Wenn der Anforderungsparameter gleich "EXCEL" ist, geben Sie eine Excel-Ansicht (AbstractJExcelView) zurück.

Datei: RevenueReportController.java

package com.example.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 revenueData = new HashMap();
        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

Erstellen Sie eine Excel-Ansicht, indem Sie die KlasseAbstractJExcelViewerweitern und die MethodebuildExcelDocument()überschreiben, um die Daten in eine Excel-Datei zu füllen. AbstractJExcelView verwendet die JExcelAPI, um die Excel-Dateidetails zu erstellen.

Note
Ausführliche Informationen zur Verwendung von JExcelAPI finden Sie unterJExcelAPI documentation

Datei: ExcelRevenueReportView.java

package com.example.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 revenueData = (Map) 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 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
Alternativ können Sie dieAbstractExcelView verwenden, die dieApache POI-API verwendet, um dieselbe Excel-Ansicht zu erstellen (sieheAbstractExcelView example).

4. Federkonfiguration

Erstellen Sie einXmlViewResolver für die Excel-Ansicht.



 

    

    
       
          /WEB-INF/spring-excel-views.xml
       
    

Datei: spring-excel-views.xml



   
   

5. Demo

Es wird eine Excel-Datei erstellt, die der Benutzer herunterladen kann.

SpringMVC-ExcelFile-Example

Quellcode herunterladen