SpringMVC與iReport(JasperReports) 5.6整合開發實例

前言

在本教程中,我們將學習如何在一個簡單的Spring MVC Web應用中集成Jasper報表工具。教程涵蓋的技術點有:報表自定義數據源的使用;報表渲染、呈現的配置與實現;iReport報表設計器的使用(報表模板設計)等。

開發環境準備

以下兩種方式任選其一:

1. 在已有的SpringMVC項目環境中進行配置(要求項目可正常運行、調試);

2. 在eclipse中安裝Spring的STS工具,然後新建一個Spring MVC Project(要求已配置好Maven環境);

項目依賴包

添加必須的jasperreports包依賴:

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <!-- iReport JasperReports -->  
  2. <dependency>  
  3.     <groupId>net.sf.jasperreports</groupId>  
  4.     <artifactId>jasperreports</artifactId>  
  5.     <version>5.6.0</version>  
  6. </dependency>  
  7. <dependency>  
  8.     <groupId>org.codehaus.groovy</groupId>  
  9.     <artifactId>groovy-all</artifactId>  
  10.     <version>2.2.2</version>  
  11. </dependency>  

SpringMvc JasperReport整合

1、繼承JasperReportsMultiFormatView類,並重寫fillReport()方法,在該方法中增加setUrl()實現,這樣就可以在controller中指定要使用的報表模板文件了。這樣做的好處是,只需要一個jasperReport配置文件,可以在controller中動態的設定報表模板url。

[java] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. package com.sample.sping_ireport;  
  2.   
  3. import java.util.Map;  
  4.   
  5. import net.sf.jasperreports.engine.JasperPrint;  
  6. import net.sf.jasperreports.engine.JasperReport;  
  7.   
  8. import org.springframework.web.servlet.view.jasperreports.JasperReportsMultiFormatView;  
  9.   
  10. public class CustomReportView extends JasperReportsMultiFormatView {  
  11.     private JasperReport report;  
  12.       
  13.     public CustomReportView() {  
  14.         super();  
  15.     }  
  16.       
  17.     protected JasperPrint fillReport(Map<String, Object> model) throws Exception {  
  18.         if (model.containsKey("url")) {  
  19.             setUrl(String.valueOf(model.get("url")));  
  20.             this.report = loadReport();  
  21.         }  
  22.           
  23.         return super.fillReport(model);  
  24.     }  
  25.       
  26.     protected JasperReport getReport() {  
  27.         return this.report;  
  28.     }  
  29. }  

2、在WEB-INF目錄下創建報表視圖配置文件jasper-views.xml,並指定解析器類爲自定義的視圖解析器類:

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    
  4.     xsi:schemaLocation="  
  5.         http://www.springframework.org/schema/beans   
  6.         http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">  
  7.   
  8.     <bean id="reportView" class="com.sample.sping_ireport.CustomReportView">  
  9.         <!-- <property name="url" value="/WEB-INF/jasper/report2.jasper"/> -->  
  10.         <property name="reportDataKey" value="jrMainDataSource"/>  
  11.     </bean>  
  12. </beans>  

3、Jasper報表的渲染需要用到XmlViewResolver視圖解析器,這樣你的項目中就會存在多個視圖解析器。需要注意的是,項目中如果使用了多個視圖解析器,則需要設置order的值來區分解析器的使用順序,order值越小則越靠前。增加XmlViewResolver視圖解析器的同時,並指定其要解析的配置文件路徑。

那麼,需要在/WEB-INF/spring/appServlet/servlet-context.xml中增加下述配置:

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <!-- 註冊XmlViewResolver,用於iReport & JasperReports報表生成 -->  
  2. <beans:bean id="jasperReportResolver" class="org.springframework.web.servlet.view.XmlViewResolver">  
  3.     <beans:property name="order">  
  4.         <beans:value>0</beans:value>  
  5.     </beans:property>  
  6.     <beans:property name="location">  
  7.         <beans:value>WEB-INF/jasper-views.xml</beans:value>  
  8.     </beans:property>  
  9. </beans:bean>  

測試準備

1、創建JavaBeanPerson實體類:

[java] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. package com.sample.sping_ireport.model;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. /** 
  7.  * iReport測試bean: Person實體類 
  8.  * @author 許亮 
  9.  * @Create 2015-2-2 17:03:44 
  10.  */  
  11. public class JavaBeanPerson {  
  12.     private String name;    // 姓名  
  13.     private String sex;     // 性別  
  14.     private int age;        // 年齡  
  15.     private String hometown;// 籍貫  
  16.     private String phone;   // 電話號碼  
  17.       
  18.     public JavaBeanPerson() {}  
  19.       
  20.     public JavaBeanPerson(String name, String sex, int age, String hometown, String phone) {  
  21.         this.name = name;  
  22.         this.sex = sex;  
  23.         this.age = age;  
  24.         this.hometown = hometown;  
  25.         this.phone = phone;  
  26.     }  
  27.       
  28.     /** 
  29.      * 姓名 
  30.      * @return 
  31.      */  
  32.     public String getName() {  
  33.         return name;  
  34.     }  
  35.   
  36.     /** 
  37.      * 姓名 
  38.      * @param name 
  39.      */  
  40.     public void setName(String name) {  
  41.         this.name = name;  
  42.     }  
  43.   
  44.     /** 
  45.      * 性別 
  46.      * @return 
  47.      */  
  48.     public String getSex() {  
  49.         return sex;  
  50.     }  
  51.   
  52.     /** 
  53.      * 性別 
  54.      * @param sex 
  55.      */  
  56.     public void setSex(String sex) {  
  57.         this.sex = sex;  
  58.     }  
  59.   
  60.     /** 
  61.      * 年齡 
  62.      * @return 
  63.      */  
  64.     public int getAge() {  
  65.         return age;  
  66.     }  
  67.   
  68.     /** 
  69.      * 年齡 
  70.      * @param age 
  71.      */  
  72.     public void setAge(int age) {  
  73.         this.age = age;  
  74.     }  
  75.   
  76.     /** 
  77.      * 籍貫 
  78.      * @return 
  79.      */  
  80.     public String getHometown() {  
  81.         return hometown;  
  82.     }  
  83.   
  84.     /** 
  85.      * 籍貫 
  86.      * @param hometown 
  87.      */  
  88.     public void setHometown(String hometown) {  
  89.         this.hometown = hometown;  
  90.     }  
  91.   
  92.     /** 
  93.      * 電話號碼 
  94.      * @return 
  95.      */  
  96.     public String getPhone() {  
  97.         return phone;  
  98.     }  
  99.   
  100.     /** 
  101.      * 電話號碼 
  102.      * @param phone 
  103.      */  
  104.     public void setPhone(String phone) {  
  105.         this.phone = phone;  
  106.     }  
  107.       
  108.     public static List<JavaBeanPerson> getList() {  
  109.         List<JavaBeanPerson> list = new ArrayList<JavaBeanPerson>();  
  110.         list.add(new JavaBeanPerson("Lily""female"22"Hubei""10086"));  
  111.         list.add(new JavaBeanPerson("Macro""male"33"Beijing""13800000000"));  
  112.         list.add(new JavaBeanPerson("Andy""male"44"HongKong""13812345678"));  
  113.         list.add(new JavaBeanPerson("Linder""female"28"Guangxi""18677778888"));  
  114.         list.add(new JavaBeanPerson("Jessie""female"26"Gansu""18219177720"));  
  115.         return list;  
  116.     }  
  117. }  

2、使用iReport設計報表模板,並編成.jasper二進制文件,並拷貝至\WEB-INF\jasper目錄下:

3、編寫Controller方法

[java] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. @RequestMapping(value = "/report", method = RequestMethod.GET)  
  2. public String report(Model model) {  
  3.     // 報表數據源  
  4.     JRDataSource jrDataSource = new JRBeanCollectionDataSource(JavaBeanPerson.getList());  
  5.           
  6.     // 動態指定報表模板url  
  7.     model.addAttribute("url""/WEB-INF/jasper/spring_report.jasper");  
  8.     model.addAttribute("format""pdf"); // 報表格式  
  9.     model.addAttribute("jrMainDataSource", jrDataSource);  
  10.           
  11.     return "reportView"// 對應jasper-views.xml中的bean id  
  12. }  

運行結果


Demo源碼下載

spring_ireport.rar

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章