原帖出处:http://zhangjunhd.blog.51cto.com/113473/23692
本文将介绍如何使用Tomcat5.0 和Apache Axis2 开发、部署及测试一个简单的Web Service 应用。
1 . 工作环境
本文将介绍如何使用Tomcat5.0 和Apache Axis2 开发、部署及测试一个简单的Web Service 应用。
1 . 工作环境
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
.检验安装
在Eclipse
下启动Tomcat
,在地址栏内输入[url]http://localhost:8080/axis2/[/url]
。
点击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();
}
}
}
|
5
.Axis2
简介
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]
。