jreport

摘要: 1 <%@ page language="java" contentType="text/html; charset=UTF-8" 2     pageEncoding="UTF-8"%> 3 <%@ page 4     import="java.io.*, 5             net.sf.jasperreports.engine.*,

1 <%@ page language="java" contentType="text/html; charset=UTF-8"
2 pageEncoding="UTF-8"%>
3 <%@ page
4 import="java.io.*,
5 net.sf.jasperreports.engine.*,
6 net.sf.jasperreports.engine.util.*,
7 java.util.*,java.sql.*,
8 net.sf.jasperreports.engine.export.*"%>
9
10
11
12
13 Insert title here
14
15
16 <%
17 File reportFile = new File(application
18 .getRealPath("jasper/Test2.jasper"));
19 JasperReport jasperReport = (JasperReport) JRLoader
20 .loadObject(reportFile.getPath());
21 Map parameters = new HashMap();
22 parameters.put("para1", "AAA");
23 Class.forName("com.mysql.jdbc.Driver");
24 Connection conn = DriverManager.getConnection(
25 "jdbc:mysql://localhost:3306/phpcms", "root", "root");
26 JasperPrint jasperPrint = JasperFillManager.fillReport(
27 jasperReport, parameters, conn);
28 JRHtmlExporter exporter = new JRHtmlExporter();
29 exporter
30 .setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
31 exporter.setParameter(JRExporterParameter.OUTPUT_WRITER, out);
32
33 exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.FALSE);
34 exporter.exportReport();
35 out.flush();
36 conn.close();
37 %>
38
39




  首先,需使用iReport制作模板,我使用的是本机Mysql数据源,取得数据库phpcms中的某个表的数据,模板字段根据SQL语句自动生成,同时手工新建一个模板变量“para1”,作为生成报表时实时变量传递。最后编译模板,生成Test2.jasper文件;

  然后打开Eclipse JEE,新建Dynamic Web Project,将Test2.jasper拷贝到项目目录webContent/jasper下,引入commons-collections.jar,commons-digester.jar,commons-logging.jar,jasperreport-3.7.2.jar,log4j.jar,mysql-connector-java.jar包,一定要引入这些包,不然似乎是无法运行起来的。



注意,如果异常提示找不到Groovy相关的类,请不要盲目的去引入Groovy包,先确认自己的模板里是否有使用Groovy脚步,如果没有的话,请检查自己的xml模板文件(*.jrxml)中jasperReport标签配置项里关于language的设置,如果是groovy,请修改为java即可。本来这个是可以通过设置iReport的全局选项的语言项来搞定,不过我尝试过修改为Java好像也不管用,不知道是否是iReport的bug



  最后,用浏览器打开验证报表生成情况,并看para1是否正确传递。

上一篇: MAVEN 入门系列一(转)
下一篇: jreport相关下载地址.
 评论 ( What Do You Think )
名称
邮箱
网址
评论
验证
   
 

 


  • 微信公众号

  • 我的微信

站点声明:

1、一号门博客CMS,由Python, MySQL, Nginx, Wsgi 强力驱动

2、部分文章或者资源来源于互联网, 有时候很难判断是否侵权, 若有侵权, 请联系邮箱:summer@yihaomen.com, 同时欢迎大家注册用户,主动发布无版权争议的 文章/资源.

3、鄂ICP备14001754号-3, 鄂公网安备 42280202422812号