Spring MVC и файл Excel через AbstractJExcelView
Spring MVC поставляется с классомAbstractJExcelView для экспорта данных в файл Excel через библиотекуJExcelAPI. В этом руководстве показано использование классаAbstractJExcelView в приложении Spring MVC для экспорта данных в файл Excel для загрузки.
2. контроллер
Класс контроллера, сгенерируйте фиктивные данные для демонстрации и получите параметр запроса, чтобы определить, какое представление вернуть. Если параметр запроса равен «EXCEL», вернуть представление Excel (AbstractJExcelView).
Файл: 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
Создайте представление Excel, расширив классAbstractJExcelView и переопределив методbuildExcelDocument() для заполнения данных в файле Excel. AbstractJExcelView использует JExcelAPI для создания деталей файла Excel.
Note
Подробнее о том, как использовать JExcelAPI, см.JExcelAPI documentation
Файл: 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
В качестве альтернативы вы можете использоватьAbstractExcelView, который использует APIApache POI для создания того же представления Excel, см. этотAbstractExcelView example.
4. Конфигурация пружины
СоздайтеXmlViewResolver для представления Excel.
/WEB-INF/spring-excel-views.xml
Файл: spring-excel-views.xml
5. Demo
Он генерирует файл Excel для загрузки пользователем.

Скачать исходный код
Скачать -SpringMVC-ExcelFile-AbstractJExcelView-Example.zip (9KB)