温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

报表设计器中使用spring框架实现自定义数据集

发布时间:2021-11-24 17:12:16 来源:亿速云 阅读:117 作者:柒染 栏目:互联网科技

本篇文章给大家分享的是有关报表设计器中使用spring框架实现自定义数据集,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

spring是一个开源框架,是为了解决企业应用程序开发复杂性而创建的。在 web 开发环境中经常会与 struts、hibernate联合起来使用,进行规范的框架结构开发。润乾中的二次开发也可以与 SSH 框架相结合部署到 web 项目中。本文介绍在设计时没有启动 web 服务,在设计器中使用 spring 的方式来实现自定义数据集。

实现思路:编写两个自定义数据集,一个在设计器中使用,一个在 web 项目中使用,在设计器中使用的类需要编写临时加载 spring 框架配置文件的代码,启动 spring 框架。Web 项目中的则不需要编写,可直接与 struts 整合,通过监听器的方式启动 struts 框架时同时启动 spring 框架。

第一步:拷贝 spring 框架 jar 包。

使用 spring 的注入方式编写一个简单的自定义数据集,首先需要将 spring 的 IOC 核心容器和对 web 支持的 jar 包拷贝到设计器的 lib 目录下(\reportHome\designer\web\WEB-INF\lib)。

第二步:编写一个简单的自定义数据集。

public class Test {  
public DataSet getDataSet(Context ctx, DataSetConfig dsc, boolean retrieve) {  
DataSet ds = new DataSet(”ds1″);// 定义数据集名称  
ds.addCol(”产品ID”);//定义显示列  
ds.addCol(”产品名称”);  
List col1 = new ArrayList();// 第一列模拟数据集合  
for (int i = 1; i <= 4; i++) {  
col1.add(i);  
}  
List col2 = new ArrayList();// 第二列模拟数据集合  
col2.add(”struts1.2″);  
col2.add(”hibernate3.1″);  
col2.add(”spring2.0″);  
col2.add(”runqian4.2.5″);  
// 设置数据  
for (int i = 0; i < col1.size(); i++) {  
Row row = ds.addRow();  
row.setData(1, col1.get(i));// 产品ID放到第一列的位置  
row.setData(2, col2.get(i));// 产品名称放到第二列的位置  
}  
return ds;  
}  
}

第三步:进行 spring 注入。

将之前编写的自定义数据集的类,通过 spring 注入的形式来实现,将 spring 的配置文件 applicationContext.xml 放置在 classpath 中(也就是设计器中的 \reportHome\designer\web\WEB-INF\classes 目录下)。使用 ApplicationContext 这个接口下的一个实现类 ClassPathXmlApplicationContext 来加载配置文件,需要注意的是,这里可以加载多个配置文件,所以是以数组形势传进的。在 applicationContext.xml 中添加节点,配置 spring 注入的代码,在类中使用 getBean() 方法,根据 xml 中 bean 节点的 id 属性注入。返回的就是该类中定义的这个成员变量了,从而实现了 spring 注入功能。

Spring 配置文件 applicationContext.xml 代码如下:

<?xml version=”1.0″ encoding=”UTF-8″?>  
< beans xmlns=”http://www.springframework.org/schema/beans”  
xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”  
xsi:schemaLocation=”http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd”>
<bean id=”Test” class=” com.runqian.Test”></bean>  
< bean id=”SpringTest” class=”com.runqian.SpringTest “>  
< property name=”test”>  
< ref bean=”Test” />  
< /property>  
< /bean>  
< /beans><?xml version=”1.0″ encoding=”UTF-8″?>

Spring 调用类代码如下:

public class SpringTest implements IDataSetFactory {  
private Test test;  
public SpringTest () {  
}  
public void setTest(Test test) {  
this.test = test;  
}  
public DataSet createDataSet(Context ctx, DataSetConfig dsc,  
boolean retrieve) {  
ApplicationContext cxt = new ClassPathXmlApplicationContext(  
new String\[\] { “applicationContext.xml” });//手动加载配置文件  
test = (Test) cxt.getBean(”Test”);//加载之前定义好的自定义数据集类  
return test.getDataSet(ctx, dsc, retrieve);  
}  
}

将之前编写的自定义数据集和 spring 调用类编译后,把.class 文件放到设计器中的 \reportHome\designer\web\WEB-INF\classes 目录下 (主意加上包文件)

第四步:启动设计器实现自定义数据集。

打开设计器,选择自定义数据集,填入 spring 调用类的包名和类名

显示出之前类中定义的列名,生成数据集成功

这样就实现了不启动 web 服务,在设计器中使用 spring 框架实现自定义数据集了。

以上就是报表设计器中使用spring框架实现自定义数据集,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI