Integrating by building a JReport Server WAR
Integrating by building a JReport Server EAR
Integrating by building a user WAR and embedding a self-contained JReport Server
Integrating by building a user EAR and embedding a self-contained JReport Server
To integrate JReport Server with your application server, you can either create a JReport Server WAR/EAR, or create your WAR/EAR and embed a self-contained JReport Server inside it. For how to create a JReport Server WAR/EAR, see Building a WAR/EAR file to Include a Self-contained JReport Server.
The self-contained JReport Server can be deployed as a single WAR file.
For example, you can create a JReport Server WAR file named jreport.war and the structure of the JReport Server WAR is as follows:
jreport.war
WEB-INF/
web.xml
lib/ -- This folder contains all resources in the JReport Server library.
admin/ -- This folder contains JSP files for the JReport Administration page.
jinfonet/ -- This folder contains JSP files for the JReport Console page.
dhtmljsp/ --This folder contains JSP files for viewing page reports.
The following is a sample of the content in the web.xml file of the JReport Server WAR:
|
The self-contained JReport Server can be deployed as a single EAR file.
For example, you can create a JReport Server EAR file named jreport.ear and the structure of the JReport Server EAR is as follows:
jreport.ear
META-INF/application.xml
jreport-lib/ -- This folder contains all resources in the JReport Server library.
jreport.war
META-INF/MANIFEST.MF
WEB-INF/web.xml
admin/
jinfonet/
dhtmljsp/
Following the Java EE standard, you should configure the META-INF/application.xml file before deploying the EAR:
|
The contents in the web.xml of the JReport Server EAR are the same as those in web.xml of the JReport Server WAR.
Since the JReport Server library is included in jreport-lib of the EAR layer, you must specify Class-Path in the META-INF/MANIFEST.MF file. The contents below should be included in the MANIFEST.MF file:
Class-Path: jreport-lib/jrenv.jar jreport-lib/JRESServlets.jar jreport-lib/JREngine.jar ...
Class-Path is a list of all packages in the JReport Server library. Each package name should start with the prefix jreport-lib/, and you should use a blank space to separate package names.
You can embed a self-contained JReport Server into your WAR.
For example, you can create a WAR named MyApp.war, and then embed a self-contained JReport Server inside it. The structure of your WAR may be as follows:
MyApp.war
WEB-INF/
web.xml
lib/ -- This folder contains all resources in the JReport Server library and your other jar files.
classes/ -- This folder contains your servlet classes.
../../asset/images/
jsp/
If you put the JReport WAR related JSPs to a sub folder, for example jreport, and this time the structure of your WAR may be as follows:
MyApp.war
WEB-INF/
web.xml
lib/ -- This folder contains all resources in the JReport Server library and your other jar files.
classes/ -- This folder contains your servlet classes.
../../asset/images/
jreport/
admin/
dhtmljsp/
jinfonet/
...
To run JReport reports, you must add the following into WEB-INF/web.xml:
<context-param>
<param-name>autoDetectServletPath</param-name>
<param-value>false</param-value>
</context-param>
Add listener as follows:
<listener>
<listener-class>jet.server.servlets.JRServerContextListener</listener-class>
</listener>
You can embed a self-contained JReport Server into your EAR in order to use JReport Server from EJB.
For example, you can create an EAR named MyApp.ear and then embed a self-contained JReport Server inside it. In the EAR, there is an EJB module used for initializing JReport Server. The structure of your EAR may be as follows:
MyEAR.ear
META-INF/application.xml
jreport-lib/ -- This folder contains all resources in the JReport Server library
MyEjb.jar
META-INF/
MANIFEST.MF
ejb-jar.xml
com/
Following the Java EE standard, you should configure the META-INF/application.xml file before deploying your EAR:
|
Since the JReport Server library is included in the jreport-lib folder of the EAR layer, you must specify Class-Path in the META-INF/MANIFEST.MF file. The contents below should be included in the MANIFEST.MF file:
Class-Path: jreport-lib/jrenv.jar jreport-lib/JRESServlets.jar jreport-lib/JREngine.jar ...
Class-Path is a list of all packages in the JReport Server library. Each package name should start with the prefix jreport-lib/, and you should use a blank space to separate package names.
If you do not want to set the reporthome for the embedded self-contained JReport Server, but instead want to use JReport's default settings, there is no requirement for configuring the ejb-jar.xml. However, if you want to control the reporthome of the JReport Server, or specify a JNDI data source for JReport Server to use, you should first configure the ejb-jar.xml file using the <env-entry></env-entry>
tags. For example:
|