WebService程序数据集
1. 问题描述
在使用WebService作为您项目如.NET系统的数据源时,希望报表中也是直接调用这个WebService数据源,而不是定义数据连接调用对应的数据库表,这样要怎么实现呢?
2. 实现思路
在程序中访问WebService应用服务,将WebService返回的数据转为程序数据集,然后在设计器中调用。
3. 示例
3.1 WebService应用服务
如在Tomcat下的Axis工程中以jws方式发布了一个WebService应用服务TestWS2TDClient.jws,返回一个数组数据。如下:
以jws方式发布WebService:将写好的TestWS2TDClient.java文件重命名为TestWS2TDClient.jws,放在Tomcat\webapps\axis2即可。
3.2 在java类中访问WebService数据源
java中发送一个soap请求,访问TestWS2TDClient.jws这个WebService,得到返回的数据,代码如下:
注:soap即简单对象访问协议,客户端发送一个请求,调用相应的对象, 然后服务器返回结果。这些消息是XML 格式的,并且封装成符合HTTP 协议的消息。
需要引入axis.jar、commons-discovery-0.2.jar、commons-logging-1.0.4.jar、wsdl4j-1.5.1.jar、log4j-1.2.8.jar、jaxrpc.jar六个包,可以在axis\WEB-INF\lib下找到。
3.3 将获得数据转为程序数据集
访问WebService后,该服务会返回数据给客户端,该例中返回一个字符串数组。定义WebServiceTableData.java类,扩展AbstractTableData,将获得的数组数据转为程序数据集。完整代码如下:
将编译好的class文件拷贝到%FR_HOME%/WebReport/WEB-INF/classes/com/fr/data文件夹下。
3.4 设计器中调用程序数据集
新建报表,定义数据集,选择程序数据集,选择定义好的程序数据集WebServiceTableData.class,自定义数据集的名称为ds1,启动tomcat服务器,点击预览,效果如下:
注:在设计器中调用程序数据集,同样要将axis下的6个包拷贝到%FR_HOME\WebReport\WEB-INF\lib目录下,否则预览是没有数据的。
返回顶部