Spring3 Web MVC 集成JasperReport生成PDF例子
一:环境搭建与配置
1. 安装JDK6以上版本
2. 安装STS, 下载地址如下:http://www.springsource.org/downloads/sts-ggts
3. 下载并安装Tomcat7
4. 创建一个Dynamic Web Project项目,然后选择创建好的项目右键选择
Configuration->convert to Manve Project.
5. 添加web.xml文件,在WEB-INF目录下新建reports, pages, classes三个子目录
6. 新建index.jsp文件在webapp目录下。
7. 最终的项目目录结构如下:

二:Spring配置详解
在web.xml中配置Spring的DispatchServlet与Context Listener,配置如下:

在express-servlet.xml中配置spring view解析器

三:Jasper Report配置详解
在jasper-views.xml添加如下配置

四:Report内容与数据源
两个报表,演示了子报表的用法,同时还演示了如何想子报表传递数据源,以及参
数传递在报表中显示图像等技巧。需要特别说明的是如果要在报表中使用图像路径
图像必须位于WEB-INF/classes下面,因为JasperReport解析是按找类路径寻找。关
于报表的详细内容建议查看下载以后的源文件,此处不再细说。
五:Controller与注解
Spring3 Controller支持注解(annotation)方式,使用非常方便,生成PDF报表的
Controller代码如下:
package com.gloomyfish.express.controllers;
import java.util.HashMap;
import java.util.Map;
import net.sf.jasperreports.engine.JRDataSource;
import net.sf.jasperreports.engine.JREmptyDataSource;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import com.gloomyfish.report.dao.MockDataFactory;
@Controller
public class JasperReportController {
protected static Logger logger = Logger.getLogger("controller");
/**
* Retrieves the PDF report file
*
* @return
*/
@RequestMapping(value = "/getpdfReport", method = RequestMethod.GET)
public ModelAndView doSalesReportPDF(ModelAndView modelAndView)
{
logger.debug("Received request to download PDF report");
// Retrieve our data from a mock data provider
MockDataFactory dataprovider = new MockDataFactory();
// Assign the datasource to an instance of JRDataSource
// JRDataSource is the datasource that Jasper understands
// This is basically a wrapper to Java's collection classes
JRDataSource categoryData = dataprovider.getCategoriesData();
// parameterMap is the Model of our application
Map<String,Object> parameterMap = new HashMap<String,Object>();
// must have the empty data source!!!
JREmptyDataSource emptyData = new JREmptyDataSource();
parameterMap.put("datasource", emptyData);
parameterMap.put("JasperfishSubReportDatasource", categoryData);
parameterMap.put("JasperfishSummaryInfo", dataprovider.getSummaryInfo());
// pdfReport is the View of our application
// This is declared inside the /WEB-INF/jasper-views.xml
modelAndView = new ModelAndView("pdfReport", parameterMap);
// Return the View and the Model combined
return modelAndView;
}
}
Mock数据工厂代码如下:
package com.gloomyfish.report.dao;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import net.sf.jasperreports.engine.JRDataSource;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
public class MockDataFactory {
public MockDataFactory()
{
System.out.println("create mock up data");
}
public GloomyFishSummaryInfoBean getSummaryInfo()
{
GloomyFishSummaryInfoBean summaryBean = new GloomyFishSummaryInfoBean();
summaryBean.setBlogURL("http://blog.csdn.net/jia20003");
summaryBean.setMajorDomain("J2SE, J2EE, WEB developer");
summaryBean.setName("jia20003");
summaryBean.setNickName("gloomyfish");
summaryBean.setRegDate("2003-03-02");
summaryBean.setWorkYears(8);
return summaryBean;
}
public JRDataSource getCategoriesData()
{
List<ArticlesCategory> listData = new ArrayList<ArticlesCategory>();
SimpleDateFormat sdf = new SimpleDateFormat("dd MMM yyyy, hh:mm:ss");
Date createDte = new Date();
ArticlesCategory category1 = new ArticlesCategory();
ArticlesCategory category2 = new ArticlesCategory();
ArticlesCategory category3 = new ArticlesCategory();
ArticlesCategory category4 = new ArticlesCategory();
ArticlesCategory category5 = new ArticlesCategory();
ArticlesCategory category6 = new ArticlesCategory();
// ArticlesCategory category7 = new ArticlesCategory();
// ArticlesCategory category8 = new ArticlesCategory();
// ArticlesCategory category9 = new ArticlesCategory();
// ArticlesCategory categoryTen = new ArticlesCategory();
category1.setCategoryName("Android Development");
category1.setCount(6);
category1.setCreateDate(sdf.format(createDte));
category2.setCategoryName("Swing Desktop Development");
category2.setCount(21);
category2.setCreateDate(sdf.format(createDte));
category3.setCategoryName("JAVA 2D Image Process");
category3.setCount(56);
category3.setCreateDate(sdf.format(createDte));
category4.setCategoryName("J2EE");
category4.setCount(8);
category4.setCreateDate(sdf.format(createDte));
category5.setCategoryName("HTML5");
category5.setCount(4);
category5.setCreateDate(sdf.format(createDte));
category6.setCategoryName("Network Protocols Research");
category6.setCount(4);
category6.setCreateDate(sdf.format(createDte));
category6.setCategoryName("ExtJS Learning");
category6.setCount(2);
category6.setCreateDate(sdf.format(createDte));
listData.add(category1);
listData.add(category2);
listData.add(category3);
listData.add(category4);
listData.add(category5);
listData.add(category6);
JRBeanCollectionDataSource data = new JRBeanCollectionDataSource(listData);
return data;
}
}
启动运行在浏览器中访问地址为:http://localhost:8080/express/hello.html
六:Deploy与运行
全部代码完成以后,从IDE中运行Maven的clean与install命令,得到war包
将war拷贝到tomcat的webapps下面即可启动tomcat然后从浏览器访问。
点击[Get PDF Report]会自动在新窗口中打开生成的PDF报表文件。
程序运行打开主页面结果如下:

获取PDF报表在浏览器中打开以后效果如下:

七:常见问题
1. 必须在applicationContext.xml中导入jasper-views.xml资源否则报表不会被编译
为jasper文件
2. Web.xml的servlet名必须与spring的xxx-servlet.xml中的xxx一致
3. Jasper-views.xml中声明的子报表路径参数与数据参数必须与报表文件jrxml中保
持一致
4. 报表中field变量名必须与Java Class中的field变量名一一对应。
八:项目文件打包下载,解压缩作为Maven项目导入以后运行clean与 install命令。
下载地址:http://download.csdn.net/detail/jia20003/4963552
转载请注明-2013-01-05