简洁axis1的应用

Axis用过一段时间后就听说Axis2横空出世,继而接触了CXF,如果不赶紧整理,怕是都要遗忘了,今天咱就先整理一下Axis1。
Axis1终于1.4版本,此后转为Axis2。

先搭建一个简单的Axis1,日后根据需要逐步求精。


在开始构建前,我们需要获得以下jar包:
引用

activation.jar
axis.jar
commons-discovery.jar
commons-logging.jar
log4j.jar
jaxrpc.jar
mail.jar
wsdl4j.jar


首先,需要在WEB-INF下构建server-config.wsdd文件,内容如下:
Xml代码

1. <?xml version="1.0" encoding="UTF-8"?>
2. <deployment
3. xmlns="http://xml.apache.org/axis/wsdd/"
4. xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
5. <transport
6. name="http">
7. <requestFlow>
8. <handler
9. type="java:org.apache.axis.handlers.http.URLMapper" />
10. </requestFlow>
11. </transport>
12. <transport
13. name="local">
14. <responseFlow>
15. <handler
16. type="java:org.apache.axis.transport.local.LocalResponder" />
17. </responseFlow>
18. </transport>
19. <service
20. name="Version"
21. provider="java:RPC">
22. <parameter
23. name="allowedMethods"
24. value="getVersion" />
25. <parameter
26. name="className"
27. value="org.apache.axis.Version" />
28. </service>
29. </deployment>

<?xml version="1.0" encoding="UTF-8"?>
<deployment
xmlns="http://xml.apache.org/axis/wsdd/"
xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
<transport
name="http">
<requestFlow>
<handler
type="java:org.apache.axis.handlers.http.URLMapper" />
</requestFlow>
</transport>
<transport
name="local">
<responseFlow>
<handler
type="java:org.apache.axis.transport.local.LocalResponder" />
</responseFlow>
</transport>
<service
name="Version"
provider="java:RPC">
<parameter
name="allowedMethods"
value="getVersion" />
<parameter
name="className"
value="org.apache.axis.Version" />
</service>
</deployment>


我们将测试Axis1内部的Version服务。
接下来,我们构建web.xml文件,如下所示:
Xml代码

1. <?xml version="1.0" encoding="UTF-8"?>
2. <web-app
3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4. xmlns="http://java.sun.com/xml/ns/javaee"
5. xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
6. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
7. id="WebApp_ID"
8. version="2.5">
9. <display-name>Apache-Axis</display-name>
10. <servlet>
11. <display-name>Apache-Axis Servlet</display-name>
12. <servlet-name>axis</servlet-name>
13. <servlet-class>org.apache.axis.transport.http.AxisServlet</servlet-class>
14. <load-on-startup>0</load-on-startup>
15. </servlet>
16. <servlet-mapping>
17. <servlet-name>axis</servlet-name>
18. <url-pattern>/services/*</url-pattern>
19. </servlet-mapping>
20. </web-app>

<?xml version="1.0" encoding="UTF-8"?>
<web-app
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID"
version="2.5">
<display-name>Apache-Axis</display-name>
<servlet>
<display-name>Apache-Axis Servlet</display-name>
<servlet-name>axis</servlet-name>
<servlet-class>org.apache.axis.transport.http.AxisServlet</servlet-class>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>axis</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
</web-app>


所有以/services/开头的请求都将转交给AxisServlet处理。
构建一个测试用例,如下所示:
Java 代码

1. import static org.junit.Assert.*;
2.
3. import java.net.URL;
4.
5. import javax.xml.namespace.QName;
6.
7. import org.apache.axis.client.Call;
8. import org.apache.axis.client.Service;
9. import org.junit.Before;
10. import org.junit.Test;
11.
12. /**
13. * WebService 测试
14. *
15. * @author 梁栋
16. * @version 1.0
17. * @since 1.0
18. */
19. public class WebServiceTest {
20. private String namespaceUri = "http://localhost:8080/axis/services/Version";
21. private String wsdlUrl = namespaceUri + "?wsdl";
22.
23.
24. /**
25. * 测试
26. *
27. * @throws Exception
28. */
29. @Test
30. public final void test() throws Exception {
31.
32. // 创建调用对象
33. Service service = new Service();
34. Call call = (Call) service.createCall();
35.
36. // 调用 远程方法
37. call.setOperationName(new QName(namespaceUri, "getVersion"));
38.
39. // 设置URL
40. call.setTargetEndpointAddress(new URL(wsdlUrl));
41.
42. // 执行远程调用,同时获得返回值
43. String version = (String) call.invoke(new Object[] {});
44.
45. // 打印信息
46. System.err.println(version);
47.
48. // 验证
49. assertNotNull(version);
50. }
51.
52. }

import static org.junit.Assert.*;

import java.net.URL;

import javax.xml.namespace.QName;

import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
import org.junit.Before;
import org.junit.Test;

/**
* WebService测试
*
* @author 梁栋
* @version 1.0
* @since 1.0
*/
public class WebServiceTest {
private String namespaceUri = "http://localhost:8080/axis/services/Version";
private String wsdlUrl = namespaceUri + "?wsdl";


/**
* 测试
*
* @throws Exception
*/
@Test
public final void test() throws Exception {

// 创建调用对象
Service service = new Service();
Call call = (Call) service.createCall();

// 调用 远程方法
call.setOperationName(new QName(namespaceUri, "getVersion"));

// 设置URL
call.setTargetEndpointAddress(new URL(wsdlUrl));

// 执行远程调用,同时获得返回值
String version = (String) call.invoke(new Object[] {});

// 打印信息
System.err.println(version);

// 验证
assertNotNull(version);
}

}



启动服务,访问地址http://localhost:8080/axis/services,得到如下页面:

单击getVersion服务,进入WSDL页面,如图所示:

我们已经能够正常访问该服务了,执行测试用例,如果我们正常获得版本信息则认为验证通过!
Axis就这么简单!
控制台得到如下信息,如图所示:



其实,在Eclipse中我们可以直接使用IDE提供的工具进行WebService验证,按下图步骤执行操作:

得到一个页面,如图所示:

继续按步骤点击,看看得到什么内容:

在Eclipse中,即便我们没有测试用例,也可使用IDE自带的工具进行验证!
 

你可能感兴趣的:(java,apache,xml,servlet,javaee)