本示例和參考文章的差別在於:
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" 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安裝文件