BIRT 怎么调用 Webservice 作为数据源

Posted xmilu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BIRT 怎么调用 Webservice 作为数据源相关的知识,希望对你有一定的参考价值。

BIRT虽然提供了访问基于SOAP的Web Services,可以使用SOAP响应作为生成报表的数据。但总的来说,操作起来还是太麻烦了,灵活性也不够:

1、配置过程步骤多,过于繁琐。

2、引入的JAR很多,太重了。

3、API接口多,代码写起来很长,调试不方便。

4、只能接收简单结果,没有二次计算的能力。

比如要处理这么个场景:根据传入参数,调用外部WebService,返回该地区的天气情况。URL:

http://www.webxml.com.cn/WebServices/WeatherWebService.asmx/getWeatherbyCityName?theCityName=...

调用服务后返回的XML数据格式如下:

<?xml version="1.0" encoding="utf-8"?>

<ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://WebXml.com.cn/">

  <string>Henan (Province).</string>

  <string>Xinyang(City).</string>

  <string>464000</string>

  <string>57297.jpg</string>

  <string>2019/12/20 16:00:31</string>

  <string>0°C/10°C</string>

  <string>December 20 is cloudy to overcast</string>

  <string>East to north is less than category 3</string>

  <string>...</string>

</ArrayOfString>

期望结构化后的效果:

 技术图片

建议使用集算器,它将HTTP服务的url串的返回结果封装成文件流,实现同样的算法只需更少的代码,分步执行调试也方便,且精心设计了一套集合运算领域的函数库,以应对结构化后的各类运算,不再需要第三方数据库来协助。最后将计算结果返回给BIRT的DataSet进行直接报表展现,比如上面的问题,只需5行:

 

A

1

=wsdl=concat(""http://www.webxml.com.cn/WebServices/WeatherWebService.asmx/getWeatherbyCityName?theCityName=",urlencode("Xinyang","UTF-8"),"":"UTF-8"")

2

=httpfile(${wsdl})

3

=xml(file(A2).read(),"ArrayOfString/string")

4

=create(${A1.(concat("str",#)).concat@c()})

5

>A4.record(A3)

其实还有很多类似的计算问题不太方便,但有集算器SPL的辅助却很简单,感兴趣可以参考:解决BIRT动态数据源的若干示例XML数据解析与计算

集算器提供了 JDBC 驱动,可以很方便的与BIRT等报表工具集成,BIRT调用SPL脚本有使用和获得它的方法。

关于集算器安装使用、获得免费授权和相关技术资料,可以参见如何使用集算器

以上是关于BIRT 怎么调用 Webservice 作为数据源的主要内容,如果未能解决你的问题,请参考以下文章

birt 报告可以调用另一个 birt 报告吗?

FineReport中以jws方式调用WebService数据源方案

BIRT 如何连接 MongoDB

BIRT 调用 SPL 脚本

如何将ListBox中选择的值发送到BIRT中的java Web服务参数?

如何实现webservice的异步调用