jasperreports+ireport製作報表筆記

来源:http://www.cnblogs.com/Mr-kevin/archive/2016/06/06/5564268.html
-Advertisement-
Play Games

一. 安裝ant 1. 解壓apache-ant-1.9.4-bin到任意地方 2. 配置環境變數ANT_HOME為apache-ant-1.9.4-bin解壓後的目錄地址,如D:\Download\apache-ant-1.9.4 3. 在環境變數CLASSPATH中加入%ANT_HOME%\li ...


一. 安裝ant  

  1. 解壓apache-ant-1.9.4-bin到任意地方  

  2. 配置環境變數ANT_HOME為apache-ant-1.9.4-bin解壓後的目錄地址,如D:\Download\apache-ant-1.9.4  

  3. 在環境變數CLASSPATH中加入%ANT_HOME%\lib;  

  4. 在環境變數Path中加入%ANT_HOME%\bin;  

  5. 在cmd下測試ant是否安裝正確,命令:ant -version     安裝成功顯示ant的版本號,出錯,自己網上查

 

二. 安裝iReport,製作報表的工具  

  1. 直接雙擊iReport-5.6.0-windows-installer.exe進行安裝

 

三. jasperreports源碼與例子  

  1. 解壓jasperreports-5.6.0-project.zip  

  2. 在含有build.xml文件的目錄執行ant -p 命令可查看可執行哪些ant命令  

  3. /jasperreports-5.6.0/src下是源碼,可在/jasperreports-5.6.0/目錄下執行ant jar來編譯源代碼,

    最後在/jasperreports-5.6.0/dist/下生成jasperreports-5.6.0.jar包

  4. /jasperreports-5.6.0/demo/samples/下是實例  

  5. /jasperreports-5.6.0/demo/samples/webapp/下是標準的實例,可在其目錄下執行ant war命令生成war包,可在tomcat下直接部署運行  

 

四. 製作一張報表  

      iReport設計報表應註意:在含有中文的地方,設置如下,防止pdf導出中文無法顯示:    

      Font  name:    宋體 (中文字體)        

      PDF font name:   STSong-Light        

      PDF  Encoding:  UniGB-UCS2-H(Chinese Siplified)        

      PDF   Embeded: √

 

五. 報表在項目中的應用  

  1. 將製作好的報表(以jrxml結尾的文件)拷貝到\WebContent\reportFiles目錄下  

  2. 添加報表的數據源類,如:

    數據源介面BaseJRDataSource.java  

1 import java.util.Map;
2 
3 import net.sf.jasperreports.engine.JRDataSource;
4 
5 public interface BaseJRDataSource extends JRDataSource{
6     public JRDataSource getInstance(Map parameters);
7     public Map<String,Object> getReportParams(Map parameters);
8 }
View Code

    具體報表的數據源類,如:

 1 import java.util.ArrayList;
 2 import java.util.List;
 3 import java.util.Map;
 4 
 5 import net.sf.jasperreports.engine.JRDataSource;
 6 import net.sf.jasperreports.engine.JRException;
 7 import net.sf.jasperreports.engine.JRField;
 8 
 9 
10 public class ×××DataSource implements BaseJRDataSource{
11     
12     private List data = new ArrayList();
13     private int index = -1;
14 
15     public ×××DataSource(){
16         // 註入spring的bean類
17     }
18     
19     /**
20      * 判斷報表是否有下一頁
21      * @return
22      */
23     @Override
24     public boolean next() throws JRException{
25         index++;
26         return (index < data.size());
27     }
28     
29     /**
30      * 根據報表欄位的名稱,格式化欄位的值
31      * @param field 報表欄位
32      * @return
33      */
34     @Override
35     public Object getFieldValue(JRField field) throws JRException{
36         Object value = null;
37         String fieldName = field.getName();
38         if ("rownum".equals(fieldName)){
39             value = index+1;
40         }
41         return value;
42     }
43     
44     /**
45      * 返回數據源實例
46      * @param parameters 參數集
47      * @return
48      */
49     @Override
50     public JRDataSource getInstance(Map parameters){
51         // 根據參數,取得報表要展示的數據
52         data = ×××;
53         index = -1;
54         return this;
55     }
56     
57     /**
58      * 返回整合後的查詢參數
59      * @param parameters 參數集
60      * @return
61      */
62     @Override
63     public Map<String, Object> getReportParams(Map parameters) {
64         return parameters;
65     }
66 
67 }
View Code

  3. 在spring的配置文件application.xml中添加數據源類的bean  

  4. 報表顯示頁面showReport.jsp,列印控制項採用jatoolsPrinter.cab,需要tomcat服務以進程的方式啟動 

  1 <%@ page contentType="text/html; charset=gb2312" language="java" %>
  2 
  3 <%@ page errorPage="error.jsp" %>
  4 <!-- spring服務定位器,可在任何地方取得bean -->
  5 <%@ page import="com.×××.×××.ServiceLocator" %>
  6 <%@ page import="com.×××.×××.datasource.BaseJRDataSource" %>
  7 <%@ page import="net.sf.jasperreports.engine.*" %>
  8 <%@ page import="net.sf.jasperreports.engine.util.*" %>
  9 <%@ page import="net.sf.jasperreports.engine.export.*" %>
 10 <%@ page import="net.sf.jasperreports.j2ee.servlets.*" %>
 11 <%@ page import="java.util.*" %>
 12 <%@ page import="java.io.*" %>
 13 <%@ page import="net.sf.json.JSONObject" %>
 14 <%
 15     request.setCharacterEncoding("UTF-8");
 16     String report = request.getParameter("jasper");
 17     String dataSource = request.getParameter("ds");
 18     String args = request.getParameter("args");
 19     String fileName = request.getParameter("fileName");
 20     Map parameters = new HashMap();
 21     
 22     JSONObject jsonMap = JSONObject.fromObject(args);  
 23     Iterator<String> it = jsonMap.keys();  
 24     while(it.hasNext()) {  
 25         String key = (String)it.next();   
 26         parameters.put(key, jsonMap.get(key));
 27     }  
 28 
 29     String appmap = request.getContextPath();
 30 
 31     File reportFile = new File(application.getRealPath("/reportFiles/"+report+".jasper"));
 32     if (!reportFile.exists()){
 33         JasperCompileManager.compileReportToFile(application.getRealPath("/reportFiles/"+report+".jrxml"));
 34         reportFile = new File(application.getRealPath("/reportFiles/"+report+".jasper"));
 35     }
 36 
 37     JasperReport jasperReport = (JasperReport)JRLoader.loadObjectFromFile(reportFile.getPath());
 38     BaseJRDataSource  baseJRDataSource=    ((BaseJRDataSource)ServiceLocator.getService(dataSource));
 39     JRDataSource jRDataSource = baseJRDataSource.getInstance(parameters);
 40     JasperPrint jasperPrint = 
 41             JasperFillManager.fillReport(
 42                 jasperReport, 
 43                 baseJRDataSource.getReportParams(parameters), 
 44                 jRDataSource
 45             );
 46     
 47     session.setAttribute(ImageServlet.DEFAULT_JASPER_PRINT_SESSION_ATTRIBUTE, jasperPrint);
 48     
 49     int pageIndex = 0;
 50     int lastPageIndex = 0;
 51     if (jasperPrint.getPages() != null){
 52         lastPageIndex = jasperPrint.getPages().size() - 1;
 53     }
 54 
 55     String pageStr = request.getParameter("page");
 56     try{
 57         pageIndex = Integer.parseInt(pageStr);
 58     }
 59     catch(Exception e){}
 60     
 61     if (pageIndex < 0){
 62         pageIndex = 0;
 63     }
 64 
 65     if (pageIndex > lastPageIndex){
 66         pageIndex = lastPageIndex;
 67     }
 68     
 69     HtmlExporter exporter = new HtmlExporter();    
 70     StringBuffer sbuffer = new StringBuffer();
 71 
 72     exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
 73     exporter.setParameter(JRExporterParameter.OUTPUT_STRING_BUFFER, sbuffer);
 74     exporter.setParameter(JRHtmlExporterParameter.IMAGES_URI, "../servlets/image?image=");
 75     //exporter.setParameter(JRExporterParameter.PAGE_INDEX, Integer.valueOf(pageIndex));
 76     exporter.setParameter(JRHtmlExporterParameter.HTML_HEADER, "");
 77     exporter.setParameter(JRHtmlExporterParameter.BETWEEN_PAGES_HTML, "");
 78     exporter.setParameter(JRHtmlExporterParameter.HTML_FOOTER, "");
 79 
 80     exporter.exportReport();
 81 %>
 82 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 83 <html>
 84 <head>
 85   <title></title>
 86   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
 87   <style type="text/css">
 88     a {text-decoration: none}
 89   </style>
 90   <OBJECT ID="jatoolsPrinter" CLASSID="CLSID:B43D3361-D075-4BE2-87FE-057188254255" codebase="jatoolsPrinter.cab#version=5,7,0,0"></OBJECT>
 91 </head>
 92 <body topmargin=0 leftmargin=0 rightmargin=0 bottomMargin=0>
 93 <table id=titleTable width=100% cellspacing=0 cellpadding=0 border=0 ><tr>
 94     <td height="25" width=100% valign="middle"  style="font-size:13px" background="toolbar-bg.gif">
 95         <table width="100%">
 96             <tr >                
 97                 <td width="100%" align="right" valign="middle"   style="font-size:12px; line-height:12px; margin:3px 0 0 0 ;" >&nbsp;
 98                 <span style=" margin:0 10px 0 0 ; padding:5px 0 0 0 ; background: url(toolbar-line.gif) no-repeat right top;">
 99                 <a href="#" onClick="doPrint('printPreview');return false;"><img src='print.gif' border=no ></a>
100                 <a href="<%=appmap%>/servlets/xls?fileName=<%=fileName %>" target="_blank"><img src='excel.gif' border=no ></a>
101                 <a href="<%=appmap%>/servlets/pdf" target="_blank"><img src='pdf.gif' border=no ></a>
102                 <a href="<%=appmap%>/servlets/docx?fileName=<%=fileName %>" target="_blank"><img src='doc.gif' border=no ></a>
103                 </span>
104                 </td>
105             </tr>
106       </table>
107     </td>
108 </table>
109 <table width="100%" cellpadding="0" cellspacing="0" border="0">
110 <td align="center">
111 <%=sbuffer.toString()%>
112 </td>
113 <script type="text/javascript">
114 function doPrint(how)
115 {   
116     //列印文檔對象
117     var myDoc ={ 
118         documents: document,    // 列印頁面(div)們在本文檔中
119         copyrights :    '傑創軟體擁有版權  www.jatools.com'      // 版權聲明,必須 
120     };
121          
122     // 調用列印方法
123     if(how == 'printPreview')
124         jatoolsPrinter.printPreview(myDoc);  // 列印預覽                
125     else if(how == 'printDialog')
126         jatoolsPrinter.print(myDoc ,true);   // 列印前彈出列印設置對話框              
127     else
128         jatoolsPrinter.print(myDoc ,false);  // 不彈出對話框列印
129 }
130 </script>
131 
132 </table>
133 </body>
134 </html>
View Code

  5. 報表顯示出錯頁面error.jsp

 1 <%@ page isErrorPage="true" %>
 2 <%@ page import="java.io.*" %>
 3 
 4 <html>
 5 <head>
 6 <title>
 7 JasperReports - Web Application Sample
 8 </title>
 9 <style type="text/css">
10 .bnew
11 {
12     font-decoration:none;
13     font-family:'DejaVu Sans', Arial, Helvetica, sans-serif;
14     font-size:10pt;
15     font-weight:bold;
16     color:#990000;
17 }
18 </style>
19 </head>
20 
21 <body bgcolor="white">
22 <span class="bnew">JasperReports encountered this error :</span>
23 <pre>
24 <% exception.printStackTrace(new PrintWriter(out)); %>
25 </pre>
26 </body>
27 </html>
View Code

  6. 若要支持pdf、img、excel、doc導出,需在web.xml中添加servlet,如下:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
 3     xmlns:web="http://xmlns.jcp.org/xml/ns/javaee" 
 4     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_4.xsd http://xmlns.jcp.org/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" 
 5     version="2.4">
 6 
 7   <servlet>
 8     <servlet-name>PdfServlet</servlet-name>

              
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • WPF綁定數據 模型類(繼承 INotifyPropertyChanged,實現屬性的變更通知) 最後的實現效果: 方法一:前臺頁面不對數據做綁定,後臺對RadGridView控制項做數據綁定 方法二:前端頁面做 ItemsSource空綁定,後臺用DataContext綁定上下文數據 記錄完成。 ...
  • 在“如何用MediaCapture解決二維碼掃描問題”這篇文章中,我們通過“成像”、“截圖”與“識別”三個步驟介紹了使用MediaCapture掃碼的主要過程及註意事項。本文主要針對“識別”的過程,對Barcode的概念作出一個較為簡單的介紹,同時也會討論ZXing的使用方法。 ZXing是一個Ja ...
  • 在WEB系統中,列印的確是比較煩人的問題,如果我們能製作一個屬於自己的自定義的列印插件,那麼我們在後續自定義列印的時候能隨心所欲的控制列印,這樣的效果對於程式員來說是非常開心的一件事件,本文將自己開發編寫的C# 製作的HTML列印插件分享出來,讓有同樣需求的朋友提供一個參考;此插件是基於Micros ...
  • 基於Jenkins快速搭建持續集成環境.(Jenkins+tortoisesvn+MSBuild) ...
  • 在初級篇中,我們接觸了: 1.url 的簡單編寫 2.兩種傳參的方式 3.捕獲的參數總是字元串 4.為視圖設置預設參數 …… 在中級篇中將更進一步。 包含其它的URLconfs 當網站非常大的時候,將所有的url都寫在一個url模塊中會非常的臃腫,且後期不便於維護。此時,就可以使用包含的方式將部分的 ...
  • Java消息服務指的是兩個應用程式之間進行非同步通信的API,它為標準消息協議和消息服務提供了一組通用介面,包括創建、發送、讀取消息等,用於支持JAVA應用程式開發。在J2EE中,當兩個應用程式使用JMS進行通信時,它們之間並不是直接相連的,而是通過一個共同的消息收發服務連接起來,可以達到解耦的效果, ...
  • 1.>在servlet中,定義成員變數是不安全的,,因為,每次請求操作的是該同一個成員變數,,會出現線程不安全的問題. 2.>而在struts2中,在Action中定義成員變數是安全的,,因此每次請求,都會重新創建一個Action,因此每次請求處理 的面對的是不同的Action,因而不會出現線程不安 ...
  • 通過註解的方式實現一個簡單的HelloWorld。 一、新建項目 同SpringMVC_HelloWorld_01 不同的是springmvc配置文件的命名和路徑,此處為src/springmvc.xml 二、配置文件 1、配置web.xml 2、配置springmvc.xml 三、編寫Contro ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...