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.
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 MaprevenueData = 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 { MaprevenueData = (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.
Quellcode herunterladen
Laden Sie es herunter -SpringMVC-ExcelFile-AbstractJExcelView-Example.zip (9KB)