历史版本23 :从数据库读取报表 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 应用场景

注:阅读本文时,请先阅读 保存模板至数据库 。

保存模板至数据库 中,可以将 cpt 模板保存入库,例如示例中将 GettingStarted.cpt 存在数据库表 report 中,那保存在数据库中的模板要如何访问呢?

保存在数据库中的模板不再通过存为模板点击预览访问,而是自定义 Java 类将其转换为网络报表,在 Web 浏览器中进行访问。如通过本文示例的方法转换后,在浏览器中输入:

http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.ReadFromDatabase&cptname=GettingStarted.cpt

就可以直接在浏览器端访问模板。

1.2 实现原理

通过程序从数据库读取报表后将其转换成程序网络报表。

2. 示例编辑

以下示例将从数据库中读取 保存模板至数据库 中保存的 GettingStarted.cpt 模板,然后将其转换成程序网络报表。

2.1 准备编译环境

编译程序前,需先创建一个 Java 工程环境,并且需要一个 Java 编辑器,如 Eclipse 或 idea 。

在编辑器工程中导入 FineReport 工程 JAR 包。包括用户自己报表工程

%FR_HOME%/lib下的所有的包,

%FR_HOME%/server/lib 下的所有包,

%FR_HOME%/webapps/webroot/WEB-INF/lib下的所有包;

代码中会将模板信息入库,还需要导入对应的 JDBC 驱动,

还要引入 JDK 下的 tools.jar。详细操作可参考:编译Java程序 

2.2 定义程序网络报表

2.2.1 编写 Java 程序

在编辑器中编写 Java 程序 ReadFromDatabase.Java,继承 com.fr.web.Reportlet 抽象类,并实现 public Report createReport(ReportletRequest reportletRequest) 方法。读取数据库中存储的 GettingStarted.cpt 模板后将其转换成程序网络报表。完整代码可参见:

cpt 模板代码:

https://code.fanruan.com/demo/example/src/branch/release/10.0/src/main/java/com/fr/demo/ReadFromDatabase.java

frm 模板代码:

  • JAR 包在 2021-04-09 之前的版本,类文件完整代码见:

注:ReadfrmFromDatabase.java 文件不支持设置了参数控件联动的模板,模板预览时,点击控件查询不能正常预览。

https://code.fanruan.com/demo/example/src/branch/release/10.0/src/main/java/com/fr/demo/ReadfrmFromDatabase.java

  • JAR 包在 2021-04-09 之后的版本,类文件完整代码见:

https://code.fanruan.com/demo/example/src/branch/release/10.0/src/main/java/com/fr/demo/NewReadFrmFromDatabase.java

2.2.2 编译 Java 文件

Java 程序编写完成后,在编译器中编译 ReadFromDatabase.java ,编译通过后,将会在编译器对应工程文件存储路径下生成 ReadFromDatabase.class 类文件。如下图所示:

2.3 发布并在 Web 端预览 

将编译后的 ReadFromDatabase.class 放到报表工程 %FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\demo目录下。如下图所示:

启动服务器,在浏览器中输入访问报表工程文件的路径,如使用本地设计器工程,启动后在浏览器端输入

注:URL 路径中 cptname 将传递模板名称到类文件,必须和类文件中的参数名称一致。

http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.NewDateDemo便可以预览报表。如下图所示:

222

决策报表浏览器端入

http://localhost:8075/webroot/decision/view/form?viewlet=com.fr.demo.ReadfrmFromDatabase&reportname=Form5.frm即可看到到报表预览效果。如下图所示:

3.png