jasperreports_JasperReports JSF插件用例系列

jasperreports

这是文章系列的切入点,在该系列文章中,我将尝试介绍JasperReport JSF插件的一些用例,该工具的创建是为了轻松地将为JasperReports设计的业务报告集成到JSF应用程序中。 该系列中描述的所有示例都可以从JasperReports JSF插件网站的“ 示例”部分获得,并将成为同一业务应用程序的一部分:在线书店。

本系列将介绍构建前面提到的Web应用程序所需的步骤。 我将尝试使文章尽可能整洁,独立且完整,但是我将故意省略某些与此处没有公开的主要技术没有特别关系的部分。 这样,每篇文章都将直达重点,并且不会冗长,从而使人们更容易理解主要演员及其角色。

在深入介绍JasperReports JSF插件的不同场景的材料之前,我们需要设置Web应用程序项目,这将是进一步使用案例的起点。 本系列中用于该项目的主要工具如下:

  • JasperReports 4.5.1:报告引擎。
  • iReport 4.5.1:可视报表设计器
  • Java Server Faces 1.2和Facelets 1.1.1:我的应用程序的Web框架(请注意,可以轻松地将其迁移到JSF 2.x中)。
  • JasperReports JSF插件 1.0:报告引擎和Web框架之间的集成桥梁。
  • Apache Derby 10.8.2.2:将保存我们所需信息的数据库。
  • Apache Tomcat 6.0.35:将用于部署和测试应用程序的应用程序服务器。

每个特定报告要显示的数据将来自具有几个表的简单数据库,这些表将保存我们所需的信息。 我将用来复合域模型的主要实体基本上是: 帐簿客户订单订单行

内容

  • 1项目设置
  • 2配置iReport
  • 3域模型
  • 4。结论

项目设置

我将采用的方法是创建一个新的基于Web的项目,该项目将使用该数据库模型。 我将使用Maven来配置和管理将要使用的依赖项,因为我已经习惯了它,这将避免我独立获取所有jar文件并在我的代码库中手动配置它们。 其他任何人都可以使用他/她喜欢的工具( Ant , Gradle ,基于IDE等)。

使用Maven做到这一点的一个很好的例子是Maven Book中的“ simple-webapp”原型样本。 我将在此处发布使用该原型生成项目结构时使用的命令行语句:

mvn archetype:create -DgroupId=net.sf.jasperreports.jsf.sample
-DartifactId=jrjsf-usecases
-Dpackage=net.sf.jasperreports.jsf.sample.usecases
-Dversion=1.0-SNAPSHOT
-DarchetypeArtifactId=maven-archetype-webapp
-DarchetypeGroupId=org.apache.maven.archetypes
-DarchetypeVersion=1.0

这将在名为jrjsf-usecases且具有以下初始值的文件夹中生成一个Maven项目:

  • groupIdnet.sf.jasperreports.jsf.sample
  • artifactIdjrjsf用例
  • 版本1.0-快照
  • net.sf.jasperreports.jsf.sample.usecases

现在,需要对pom.xml文件进行一些修改,以保存我们项目所需的依赖项。 我将做的主要更改将包括添加对Java 1.5(及更高版本)的支持以及对本文开头列出的项目的依赖性。

为了能够使用Java 5发行后添加到Java的泛型和其他高级功能,我们需要配置maven-compiler-plugin,以便Java编译器可以识别出我们希望支持这些功能:

<project>...<build><plugins><plugin><artifactId>maven-compiler-plugin</artifactId><groupId>org.apache.maven.plugins</groupId><configuration><source>1.5</source><target>1.5</target></configuration></plugin></plugins></build>
</project>

现在,让我们添加实现应用程序所需的依赖项:

<project>...<dependencies><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.4</version><scope>provided</scope></dependency><dependency><groupId>javax.servlet.jsp</groupId><artifactId>jsp-api</artifactId><version>2.0</version><scope>provided</scope></dependency><dependency><groupId>javax.el</groupId><artifactId>el-api</artifactId><version>1.0</version></dependency><dependency><groupId>javax.faces</groupId><artifactId>jsf-api</artifactId><version>1.2_14</version></dependency><dependency><groupId>javax.faces</groupId><artifactId>jsf-impl</artifactId><version>1.2_14</version></dependency><dependency><groupId>com.sun.facelets</groupId><artifactId>jsf-facelets</artifactId><version>1.1.1</version></dependency><dependency><groupId>net.sf.jasperreports</groupId><artifactId>jasperreports</artifactId><version>4.5.1</version></dependency><dependency><groupId>net.sf.jasperreports.jsf</groupId><artifactId>jasperreports-jsf</artifactId><version>1.0</version></dependency><dependency><groupId>org.apache.derby</groupId><artifactId>derbyclient</artifactId><version>10.8.2.2</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.8.1</version><scope>test</scope></dependency></dependencies>
</project>

在此项目中,我们将使用可通过JNDI访问的容器管理数据源。 这种配置取决于我们使用的应用程序服务器的类型。 由于我将Tomcat用作应用程序服务器,因此需要在项目中的src / main / webapp / META-INF文件夹下添加一个context.xml文件,以告诉它如何访问该数据库以及资源的类型。我想要:

<Context path='/jrjsf-usecases' reloadable='true'><Resource name='jdbc/BookStoreDB' auth='Container' type='javax.sql.DataSource'maxActive='100' maxIdle='30' maxWait='10000'username='app' password='' driverClassName='org.apache.derby.jdbc.ClientDriver'url='jdbc:derby://localhost:1527/bookstoredb;create=true'/></Context>

配置iReport

我们需要配置iReport使其能够连接到数据库,因此让我们启动iReport设计工具并对其进行配置以使其可以进行设计工作。 iReport的不带至Apache Derby数据库的支持外的开箱 ,我们需要将库添加到其类路径和手工配置Derby JDBC驱动程序。 该练习将教我们如何配置工具以支持其他任何数据库。

首先,从Apache Derby数据库的网站下载Apache Derby数据库,并将其安装(解压缩zip文件)到本地计算机中您选择的文件夹中(如果尚未执行的话)。 然后打开iReport的首选项/选项窗口,然后选择类路径选项卡:

我将把Derby的lib文件夹添加到iReport类路径中。 为此,请单击“添加文件夹”按钮并浏览文件系统,直到获得Apache Derby安装中的lib文件夹:

完成后,在首选项窗口中单击“确定”按钮,现在iReport中应该可以使用Apache Derby客户端类。 现在,我们准备在iReport中配置Apache Derby数据源,该数据源将由我们的报告使用。 要添加新的数据源,我们可以从iReport欢迎页面开始,然后单击“ 步骤1 :创建数据库连接...”按钮,或者单击工具栏上的“报告数据源”按钮,然后单击“添加”。按钮。 无论哪种方式,我们都将到达如下所示的窗口:

需要在iReport中手动配置Apache Derby数据源,因此在上一个窗口的列表中选择“数据库JDBC连接”,单击“下一步>”,然后在下一个窗口中填写JDBC驱动程序的值:

字段的值如下:

  • 名称BookStoreDB
  • JDBC驱动程序org.apache.derby.jdbc.ClientDriver
  • JDBC URLjdbc:derby:// localhost:1527 / bookstoredb
  • 用户名app
  • 密码<空>

现在,在继续之前,请确保您的Apache Derby实例正在运行以允许与其建立连接,然后单击“测试”按钮以检查一切是否正常。

领域模型

假设我们已经配置了项目并准备好开始工作(我们有一个基本的项目文件夹结构,所有基本依赖项都在我们的类路径中,并且iReport能够连接到我们的数据库),所以让我们从码。 我在这方面的第一步将是创建一个SQL文件( bookstore.create.sql ),以初始化我在本系列的Introduction部分中所讨论的域模型。 复制此段下面的文本并将其粘贴到项目文件夹结构内的文件中,以便以后使用:

create table book (book_id int generated by default as identity primary key,title varchar(50) not null,author varchar(50) not null,published_year varchar(4) not null,genre varchar(20) not null,price numeric not null
);create table customer (customer_id int generated by default as identity primary key,name varchar(250) not null
);create table purchase_order (order_id int generated by default as identity primary key,customer_id int not null,created_date date not null,constraint customer_fk foreign key (customer_id) references customer(customer_id)
);create table purchase_order_line (order_line_id int generated by default as identity primary key,order_id int not null,book_id int not null,item_count int not null,constraint order_fk foreign key (order_id) references purchase_order(order_id),constraint book_fk foreign key (book_id) references book(book_id)
);

这只是我的域模型的后端部分,在我的应用程序中,我还需要将那些实体表示为Java类。 因此,要使此域模型完整,下一步是编写Java类,该类需要表示Java应用程序中先前定义的域模型。 现在该看看以前的模型了,我们有4个不同的实体,因此我们将需要在Java应用程序中使用4个不同的类来遵守该模型:

public class Book {private Long id;private String title;private String author;private String publishedYear;private String genre;private double price;public String getAuthor() {return author;}public void setAuthor(String author) {this.author = author;}public String getGenre() {return genre;}public void setGenre(String genre) {this.genre = genre;}public Long getId() {return id;}public void setId(Long id) {this.id = id;}public double getPrice() {return price;}public void setPrice(double price) {this.price = price;}public String getPublishedYear() {return publishedYear;}public void setPublishedYear(String publishedYear) {this.publishedYear = publishedYear;}public String getTitle() {return title;}public void setTitle(String title) {this.title = title;}}

顾客

public class Customer {private Long id;private String name;public Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}}

订购

public class Order {private Long id;private Customer customer;private Date createdDate;private List lines = new ArrayList();public Date getCreatedDate() {return createdDate;}public void setCreatedDate(Date createdDate) {this.createdDate = createdDate;}public Customer getCustomer() {return customer;}public void setCustomer(Customer customer) {this.customer = customer;}public Long getId() {return id;}public void setId(Long id) {this.id = id;}public List getLines() {return lines;}public void setLines(List lines) {this.lines = lines;}}

订单行

public class OrderLine {private Long id;private Order order;private Book book;private int itemCount;public Book getBook() {return book;}public void setBook(Book book) {this.book = book;}public Long getId() {return id;}public void setId(Long id) {this.id = id;}public int getItemCount() {return itemCount;}public void setItemCount(int itemCount) {this.itemCount = itemCount;}public Order getOrder() {return order;}public void setOrder(Order order) {this.order = order;}}

现在,使用您选择的工具连接到数据库,并执行bookstoredb.create.sql文件创建表结构。

结论

我试图使代码尽可能简单和干净。 上一节中列出的Java类可以使用ORM工具(例如Hibernate , iBATIS , Ebean等)映射到我们的关系数据库。我将对象关系映射层的选择留给读者,因为有很多选择,但是没有一个选择将影响我们将报告与Web框架集成的方式。

我们的Web应用程序应包含其他类,以将其体系结构构成为DAO和业务外观以及视图控制器。 但是,出于与我没有添加任何可能有助于将模型类链接到数据库表的ORM信息相同的原因,在本文中添加所有它们完全超出了范围。 如今有很多IoC容器( Spring框架 , Weld , Seam等),本系列中真正重要的是演示JasperReports JSF插件的用法。 (由于它们是每个特定用例的一部分,因此将在其特定的文章中列出视图控制器)。

这就是我们开始在这个漂亮工具的不同示例中所做的全部。 在接下来的几周中,新文章将在JasperReports JSF插件类别下发布,并提供详细的示例来演示如何实现最常见的用例。 希望您喜欢它们,欢迎任何评论。

参考:来自Code Nibbles博客的JCG合作伙伴 Alonso Dominguez的JasperReports JSF插件用例系列 。


翻译自: https://www.javacodegeeks.com/2012/06/jasperreports-jsf-plugin-use-cases.html

jasperreports

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/354975.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RN 47 中的 JS 线程及 RunLoop

RCBridge 初始化时声明了一个 CADisplayLink _jsDisplayLink [CADisplayLink displayLinkWithTarget:self selector:selector(_jsThreadUpdate:)];在 _jsThreadUpdate 函数中&#xff0c;处理界面更新。这个 CADisplayLink 随后被加到 JS 线程对应的 RunLoop 中。 - (void)ad…

java nginx https_docker nginx 配置ssl,实现https

docker nginx 配置ssl&#xff0c;实现https2019-09-05 16:06:35.0nginx配置https总览在nginx配置ssl实现https&#xff0c;简单来说分为三个步骤&#xff1a;1 上传ssl证书等文件将 1_www.domain.com_bundle.crt 和 2_www.domain.com.key 上传到nginx配置文件的目录旁边。这两…

JavaScript入门几个概念

JavaScript入门几个概念 刚刚入门JavaScript的时候&#xff0c;搞懂DOM、BOM以及它们的对象document和window很有必要。 DOM是为了操作文档出现的API&#xff0c;document是它的一个对象。BOM是为了操作浏览器出现的API&#xff0c;window是它的一个对象。DOM When a web page …

微服务有麻烦吗? Lagom在这里为您提供帮助。 尝试一下!

蛋糕支持。 我们很自豪地宣布&#xff0c;新的Apache许可的微服务框架Lagom可在GitHub上使用 &#xff01; 当其他框架专注于打包和实例启动时&#xff0c;Lagom重新定义了Java开发人员构建基于微服务的应用程序的方式。 服务是异步的。 服务内通信由您管理。 流是开箱即用的。…

海思芯片硬件java加速_海思芯片直播延迟测试结果(小于100毫秒)

背景最近接触了许多客户&#xff0c;许多是做安全方面产品的客户&#xff0c;有些还涉及到jun队后勤的等等&#xff0c;他们普遍对采集延迟&#xff0c;编码延迟&#xff0c;传输延迟等都有很大关注。例如有个客户是做反狙击探测的&#xff0c;那可是与生命相关的&#xff0c;容…

java jsp登录的验证码_Java Web实现登录验证码(Servlet+jsp)

1.生成验证码图片(Servlet)importjava.awt.Color;importjava.awt.Font;importjava.awt.Graphics2D;importjava.awt.image.BufferedImage;importjava.io.IOException;importjava.util.Random;importjavax.imageio.ImageIO;importjavax.servlet.ServletException;importjavax.ser…

shrinkwrap_Java EE 6测试第二部分– Arquillian和ShrinkWrap简介

shrinkwrap在Java EE 6测试的第一部分中&#xff0c;我简要介绍了使用Glassfish嵌入式容器的EJB 3.1 Embeddable API&#xff0c;以演示如何启动该容器&#xff0c;如何在项目类路径中查找bean以及运行非常简单的集成测试。 这篇文章重点介绍Arquillian和ShrinkWrap以及为什么它…

java中三个基本框架_对于Java基础者应该如何理解Java中的三大框架!

三大框架&#xff1a;StrutsHibernateSpringJava三大框架主要用来做WEN应用。Struts主要负责表示层的显示Spring利用它的IOC和AOP来处理控制业务(负责对数据库的操作)Hibernate主要是数据持久化到数据库再用jsp的servlet做网页开发的时候有个 web.xml的映射文件&#xff0c;里面…

Apache Camel的性能调整思路

时不时地&#xff0c;我会以Camel速度较慢的说法来询问有关优化Camel应用程序的问题。 骆驼只是连接不同系统的粘合剂&#xff0c;路由引擎全都在内存中&#xff0c;并且不需要任何持久状态。 因此&#xff0c;在99&#xff05;的情况下&#xff0c;性能问题是由于其他系统的瓶…

java虚拟机源码怎么看_java虚拟机JVM第4讲:从源代码到机器码,发生了什么?

在上篇文章我们聊到&#xff0c;无论什么语言写的代码&#xff0c;其到最后都是通过机器码运行的&#xff0c;无一例外。那么对于 Java 语言来说&#xff0c;其从源代码到机器码&#xff0c;这中间到底发生了什么呢&#xff1f;这就是今天我们要聊的。如下图所示&#xff0c;编…

java构建内存池队列_池化技术(线程池、连接池、内存池等)

一、池化技术 -简单点来说&#xff0c;就是提前保存大量的资源&#xff0c;以备不时之需。对于线程&#xff0c;内存&#xff0c;oracle的连接对象等等&#xff0c;这些都是资源&#xff0c;程序中当你创建一个线程或者在堆上申请一块内存时&#xff0c;都涉及到很多系统调用&a…

java 堆大小_适当的Java堆大小的5个技巧

java 堆大小确定生产系统合适的Java堆大小不是一件容易的事。 在我的Java EE企业经验中&#xff0c;由于Java堆容量和调整不足&#xff0c;我遇到了多个性能问题案例。 本文将为您提供5个技巧&#xff0c;这些技巧可以帮助您确定当前或新生产环境的最佳Java堆大小。 这些技巧中…

jcmd:一个可以全部统治的JDK命令行工具

我在过去的几篇文章中都引用了方便的JDK工具jcmd &#xff0c;但是像我以前对jps所做的那样&#xff0c;仅专注于其实用性 。 jcmd工具是随Oracle Java 7引入的&#xff0c;在通过使用Java标识Java进程的ID &#xff08;与jps相似&#xff09;&#xff0c;获取堆转储 &#xff…

ansible-playbook实操之一键搭建lnmp+wordpress

目录 1、架构和准备&#xff1a; 2、配置nginx角色&#xff1a; 3、配置mariadb角色&#xff1a; 4、配置php角色&#xff1a; 5、配置完之后&#xff0c;写脚本调用roles 6、配置完之后浏览器搭建wordpress&#xff1a; 1、架构和准备&#xff1a; 操控节点&#xff1a;…

pivot 与 unpivot 函数是SQL05新提供的2个函数

pivot 与 unpivot 函数是SQL05新提供的2个函数 ------------------------------------------------------------------------------ pivot函数&#xff1a; create table test(id int,name varchar(20),quarter int,profile int)insert into test values(1,a,1,1000)insert i…

python SimpleHTTPServer 快速共享文件

简单介绍 通过一个python命令快速共享文件给他人。 操作步骤 1、打开cmd命令行&#xff0c;切换到需要共享文件的目录&#xff0c;执行命令 python -m SimpleHTTPServer 。 2、打开浏览器&#xff0c;在地址栏中输入http://10.10.11.164:8000或者http://localhost:8000/可以看到…

mysql数据库设计实现工作流_工作流activiti部署到数据库(1)

1.工作流定义(workflow):指"业务过程的部分或整体在计算机应用环境下的自动化".普通框架要有一个请假单,要有一个字段来标识请假单的状态,至少有三个,还有请假单的状态是走到那个经理审批还是老板审批,这个时候不便管理.BPM:业务流程管理框架,是用来管理流程的框架.B…

abd.exe 需要下java吗_Abd.exe文件下载|

abd.exe在哪个位置&#xff1f;abd.exe是一款很重要的电脑文件&#xff0c;如果这个文件丢失了&#xff0c;电脑部分程序将会无法正常运行&#xff0c;所以大家应该重视这类文件&#xff0c;小编已经将这个文件打包好了&#xff0c;欢迎大家来当易网下载。exe文件简介EXE File …

Spark面对OOM问题的解决方法及优化总结 (转载)

Spark面对OOM问题的解决方法及优化总结 (转载) 转载地址&#xff1a; http://blog.csdn.net/yhb315279058/article/details/51035631 Spark中的OOM问题不外乎以下两种情况map执行中内存溢出shuffle后内存溢出map执行中内存溢出代表了所有map类型的操作&#xff0c;包括&#xf…

通过此注释改善您的JUnit体验

JUnit可能是所有Java项目中90&#xff05;的一部分。 令人兴奋的是&#xff0c;我们很快将拥有支持Java 8的JUnit 5 。 我们最近在博客上发表了一项改进 。 回到JUnit 4领域&#xff0c;有一个小技巧&#xff0c;我只能建议您进行所有单元测试。 只需在此处添加这个小注释&…