前言:
最近在开发中需要调用对方的 webservice服务,按照现有的技术,本应该是一件很简单的事情,只需要拿到wsdl文件,生成客户端代码即可,但是,对方的webservice服务是06年用axis1.4生成发布的,wsdl文件只能用axis1.4生成客户端代码,而axis的jar包和程序部署环境WebSphere8.5冲突,导致程序无法启动。之前的测试中,spring的WebServiceTemplate可以在was环境下使用,所以,写一下spring如何手动编写客户端代码,调用axis1.4的服务端。
解决方案:
不管用什么工具生成的webservice客户端代码,最终都工具根据生产的代码组装为符合soap协议的xml文件发送给服务端,接收服务端返回的xml文件,解析成我们需要的对象。虽然spring无法根据axis1.4的wsdl文件生成客户端javaBean对象,但是可以先根据wsdl解析到要发送给服务端的 xml文件的格式,由xml文件反向推导出spring组装此xml文件的javaBean对象,所以重点就是如何根据wsdl解析出服务端需要的xml文件,和 spring javaBean和xml文件的对应规则。
-
根据wsdl拿到要发送给服务端的xml文件,
这里根据wsdl的语法和soap协议规范,可以自己解析,但是比较费时,所以推荐一个工具:soapUI,可以根据wsdl文件生成要发送给服务端的xml文件以及对应服务端返回的xml文件(只是这个工具的一个小功能),本文用的soapUI版本是5.2.1
请求的xml文件实例:
应答xml文件实例:
1 <soapenv:Envelope xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"> 2 <soapenv:Header/> 3 <soapenv:Body> 4 <sayHelloResponse soapenv:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"> 5 <sayHelloReturn xsi:type="xsd:string">?</sayHelloReturn > 6 </sayHelloResponse> 7 </soapenv:Body> 8 </soapenv:Envelope>
2. 根据xml编写javaBean
对应关系:请求报文中 Body标签内的 标签就是服务端方法的描述,
sayHello --> 服务端的方法名 --> javaBean类 --> @XmlRootElement 中的name的值
sayHello的子标签是方法的参数,后面定义了参数的类型
message --> 方法参数 --> javaBean的字段 --> @XmlElement 中的name的值
请求javaBean实例
应答javaBean实例
3. spring WebserviceTemplate调用
spring的WebserviceTemplate使用这里不做详解了,需要配置WebserviceTemplate的bean和解析xml文件的 Marshaller bean