本示例和参考文章的差别在于:
1)deploy.wsdd定义的更详细(对于server端定义了接口:ICalculate):
<deployment xmlns="http://xml.apache.org/axis/wsdd/"
xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
<service name="Calculate" provider="java:RPC" style="rpc" use="literal">
<parameter name="wsdlTargetNamespace" value="http://web.webservice.CalculateService.org" />
<parameter name="wsdlServiceElement" value="Calculate" />
<parameter name="wsdlServicePort" value="CalculateService" />
<parameter name="wsdlPortType" value="ICalculate" />
<parameter name="className" value="org.calculateservice.service.CalculateImp" />
<parameter name="typeMappingVersion" value="1.2" />
<parameter name="allowedMethods" value="add sub" />
<parameter name="scope" value="Request" />
<operation name="add" qname="operNS:add"
xmlns:operNS="http://web.webservice.CalculateService.org"
returnQName="addReturn" returnType="rtns:int" xmlns:rtns="http://www.w3.org/2001/XMLSchema"
soapAction="">
<parameter qname="x" type="tns:int"
xmlns:tns="http://www.w3.org/2001/XMLSchema" />
<parameter qname="y" type="tns:int"
xmlns:tns="http://www.w3.org/2001/XMLSchema" />
</operation>
<operation name="sub" qname="operNS:sub"
xmlns:operNS="http://web.webservice.CalculateService.org"
returnQName="subReturn" returnType="rtns:int" xmlns:rtns="http://www.w3.org/2001/XMLSchema"
soapAction="">
<parameter qname="x" type="tns:int"
xmlns:tns="http://www.w3.org/2001/XMLSchema" />
<parameter qname="y" type="tns:int"
xmlns:tns="http://www.w3.org/2001/XMLSchema" />
</operation>
</service>
</deployment>
2)自定义了AxisServlet:org.calculateservice.core.AxisServlet(兼容了.NET 去掉了SOAPACTION的检验);详细代码这里不贴了,感兴趣自行下载完整示例代码;
3)调用方式为用本地类调用(java调用WS好像有三种方式,个人感觉用本地代理类调用最为合理和可读):
public static void main(String[] args) throws ServiceException, RemoteException {
Calculate calculate = new CalculateLocator();
int result = calculate.getCalculateService().add(1, 2);
System.out.println("[%1 + 2 = " + result + "%]");
}
发布/调用WS的主要步骤:1)将下载资源中的axis1.4安装包中的webapp中的axis目录copy到tomcat中的webapp目录中;
2)编写WS服务端实现代码;
3)在WEB-INF目录编写deploy.wsdd部署文件;
4)编写:generate-server-config.bat脚本,然后生成:server-config.wsdd,然后发布webservice;
5)编写:wsdl2java.bat脚本生成本地调用client代码;
6)编写测试代码调用WS;
代码结构图:
client:用WSDL2Java根据wsdl生成本地的client代码;
core:自定义的AxisServlet,兼容了.NET 去掉了SOAPACTION的检验;
service:WS服务端实现代码(这里用一个简单的加减计算做为实例);
test:根据生成的client类去调用server(生成的代码server地址是localhost的,如果需要将此地址改为配置,修改CalculateLocator类中变量CalculateService_address赋值即可);
点击下载完整示例
资源中包含示例完整代码和axis1.4安装文件