Eclipse 3.1.2+Lomboz+jdk1.5+ apache-tomcat-5.0.18+AXIS2:1.0(war版本和bin版本)
在[url]http://ws.apache.org/axis2/download/1_0/download.cgi[/url]頁面下,下載AXIS2的Binary Distribution url: [url]http://apache.justdn.org/ws/axis2/1_0/axis2-std-1.0-bin.zip[/url]和war Distribution url: [url]http://apache.justdn.org/ws/axis2/1_0/axis2-1.0-docs.zip[/url]。把這兩個文件解壓,比如解壓縮的后得目錄為C:"axis2-std-1.0-bin和C:"axis2.war。
在Eclipse下通過菜單window—preferences…--Java—Build Path—User Libraries 新建一個user library,比如名字就叫axis2把C:"axis2-std-1.0-bin"lib下的所有jar文件包含進來。把axis2.war拷貝到%TOMCAT-HOME%/webapps下面。
2.檢驗安裝
點擊Validate,將到達 Axis2 Happiness Page。
3.WebService中的HelloWorld
1)新建一個動態web工程,取名ZZaxis,右鍵點擊項目名,選擇Properties-Java Build Path-Add Library-User Library-axis2。
2)新建package sample,建立HelloWorld.java,代碼如下。
HelloWorld.java
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
public class HelloWorld {
public OMElement sayHello(OMElement in){
String name=in.getText();
String info=name+"HelloWorld!";
OMFactory fac=OMAbstractFactory.getOMFactory();
OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
resp.setText(info);
return resp;
}
}
|
3)在WebContent"META-INF"建立services.xml,代碼如下。
services.xml
<?xml version="1.0" encoding="UTF-8"?>
<service name="HelloWorld">
<description>
This is a sample Web Service.
</description>
<parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
<operation name="sayHello">
<messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
</operation>
</service>
|
4)將目錄sample和目錄META-INF組織如下(新建目錄example)。
+-example
|-------- +-sample
|------- HelloWorld.class
|---------+-META-INF
|-------services.xml
5)打包生成aar文件。
在命令符環境下,將當前目錄轉到example。
jar cvf HelloWorld.aar . //注意最后一個點,在當前目錄下生成HelloWorld.aar。
6)在Eclipse中啟動Tomcat,在地址欄下鍵入[url]http://localhost:8080/axis2/[/url]。選擇Administration,輸入用戶名admin,密碼axis2。選擇左側工具欄Tools- Upload Service,上傳之前打包的HelloWorld.aar。該文件將在<CATALINA_HOME>/webapps/axis2"WEB-INF"services目錄下。
7)編寫客戶端檢驗代碼。新建Java Project,取名為ZZaxisClient。右鍵點擊項目名,選擇Properties-Java Build Path-Add Library-User Library-axis2。
8)新建package example.client。建立TestClient.java,代碼如下。
TestClient.java
package example.client;
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
public class TestClient {
private static EndpointReference targetEPR=new EndpointReference
("http://localhost:8080/axis2/services/HelloWorld");
public static OMElement getSayHelloOMElement(){
OMFactory fac=OMAbstractFactory.getOMFactory();
OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
OMElement method=fac.createOMElement("sayHello",omNs);
method.setText("ZJ");
return method;
}
public static void main(String[] args){
try{
Options options=new Options();
options.setTo(targetEPR);
ServiceClient sender=new ServiceClient();
sender.setOptions(options);
OMElement sayHello=TestClient.getSayHelloOMElement();
OMElement result=sender.sendReceive(sayHello);
System.out.println(result);
}
catch(Exception axisFault){
axisFault.printStackTrace();
}
}
}
|
9)測試,run TestClient.java as Java Application。結果:
<hw:sayHelloResponse xmlns:hw="http://helloworld.com/"
xmlns:tns="http://ws.apache.org/axis2">
ZJHelloWorld!
</hw:sayHelloResponse>
1.HelloWorld做了些什么?
HelloWorld功能非常簡單,在客戶端輸入你的姓名,本例中為ZJ。參數傳遞到服務器端后,經過處理將返回name+"HelloWorld!",本例中為ZJ HelloWorld!
2.服務器端文件HelloWorld.java
HelloWorld.java
package sample;
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
public class HelloWorld {
//讀取client端getSayHelloOMElement()方法傳遞的參數in。
public OMElement sayHello(OMElement in){
//將in轉換為String。
String name=in.getText();
String info=name+"HelloWorld!";
//創建response SOAP包。
OMFactory fac=OMAbstractFactory.getOMFactory();
// OMNamespace指定此SOAP文檔名稱空間。
OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
//創建元素sayHello,并指定其在omNs指代的名稱空間中。
OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
//指定元素的文本內容。
resp.setText(info);
return resp;
}
}
|
3.services.xml部署文件
services.xml
<?xml version="1.0" encoding="UTF-8"?>
//下面定義服務名
<service name="HelloWorld">
<description>
This is a sample Web Service.
</description>
// ServiceClass指定Java Class的位置,即實現服務的類。
<parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
// operation 與Java Class中方法名對應。
<operation name="sayHello">
// messageReceiver看下文注解。
<messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
</operation>
</service>
|
注解:消息交換模式。
目前Axis2支持三種模式:In-Only、Robust-In和In-Out。In-Only消息交換模式只有SOAP請求,而不需要應答;Robust-In消息交換模式發送SOAP請求,只有在出錯的情況下才返回應答;In-Out消息交換模式總是存在SOAP請求和應答。本例使用In-Out模式。
4.客戶端文件TestClient.java
TestClient.java
package example.client;
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
public class TestClient {
// targetEPR指定打包的Service(.aar文件)在容器中的物理位置。
private static EndpointReference targetEPR=new EndpointReference
("http://localhost:8080/axis2/services/HelloWorld");
public static OMElement getSayHelloOMElement(){
//創建request SOAP包。
OMFactory fac=OMAbstractFactory.getOMFactory();
// OMNamespace指定此SOAP文檔名稱空間。
OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
//創建元素sayHello,并指定其在omNs指代的名稱空間中。
OMElement method=fac.createOMElement("sayHello",omNs);
//指定元素的文本內容。
method.setText("ZJ");
return method;
}
public static void main(String[] args){
try{
Options options=new Options();
options.setTo(targetEPR);
ServiceClient sender=new ServiceClient();
sender.setOptions(options);
OMElement sayHello=TestClient.getSayHelloOMElement();
//發出request SOAP,
//同時將得到的遠端由sayHello方法返回的信息保存到result。
//通過services.xml能準確找到sayHello方法所在的文件。
OMElement result=sender.sendReceive(sayHello);
}
catch(Exception axisFault){
axisFault.printStackTrace();
}
}
}
|
Apache Axis2 是Axis的后續版本,是新一代的SOAP引擎。Axis2的主要特點有:
1)采用名為 AXIOM(AXIs Object Model)的新核心 XML 處理模型,利用新的XML解析器提供的靈活性按需構造對象模型。
2)支持不同的消息交換模式。目前Axis2支持三種模式:In-Only、Robust-In和In-Out。In-Only消息交換模式只有SOAP請求,而不需要應答;Robust-In消息交換模式發送SOAP請求,只有在出錯的情況下才返回應答;In-Out消息交換模式總是存在SOAP請求和應答。
3)提供阻塞和非阻塞客戶端 API。
4)支持內置的 Web服務尋址 (WS-Addressing) 。
5)靈活的數據綁定,可以選擇直接使用 AXIOM,使用與原來的 Axis 相似的簡單數據綁定方法,或使用 XMLBeans、JiBX 或 JAXB 2.0 等專用數據綁定框架。
6)新的部署模型,支持熱部署。
7)支持HTTP,SMTP,JMS,TCP傳輸協議。
8)支持REST (Representational State Transfer)。
6.Axis2 支持的規范包括:
-SOAP 1.1 and 1.2
-Message Transmission Optimization Mechanism (MTOM), XML Optimized Packaging (XOP) and SOAP with Attachments
-WSDL 1.1, including both SOAP and HTTP bindings
-WS-Addressing (submission and final)
-WS-Policy
-SAAJ 1.1
有關Axis2更加詳細的介紹,可以訪問Axis2網站[url]http://ws.apache.org/axis2/[/url]。