网上看了很久的axis2,发现大部分都是单独发布axis2服务,这个和实际接口的使用情况严重不符,我通过网上搜寻终于完成axis2与已有项目完美集成,现将经验总结如下:
1、将axis2.war解压开,将conf,lib,modules,service 四个文件夹复制到已有项目的WEB-INF下。
2、开发接口类
package Axis2Service.service;
/**
* desc:计算俩个数和值的 webservice接口
*
* @version SVN $Revision: 1.1 $ $Date: 2011/07/12 02:06:49 $
*/
public class Calculate {
public Integer sum(Integer num1, Integer num2) {
return num1 + num2;
}
}
3、在services文件下新建一个文件夹(任意取名),再新建META-INF文件夹,最后再新增services.xml,接口信息就写在这里面。
具体路径:WEB-INF/services/myservice/META-INF/services.xml 。
4、编写services.xml信息如下:
<service name="AxisService">
<description>AxisService</description>
<parameter name="ServiceClass">
Axis2Service.service.Calculate
</parameter>
<operation name="sum">
<messageReceiver class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
</operation>
</service>
5、将如下代码添加到web.xml中
<servlet>
<servlet-name>AxisServlet</servlet-name>
<servlet-class>
org.apache.axis2.transport.http.AxisServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>AxisServlet</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
6.发布项目,然后在地址栏上输入http://localhost:8080/MyAxis/services/AxisService?wsdl,就能看到发布的项目了哦!!
7、编写客户端程序
package client;
import javax.xml.namespace.QName;
import org.apache.axis2.AxisFault;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.rpc.client.RPCServiceClient;
public class CalculateClient {
public static void main(String[] args){
String url="http://localhost:8080/LoginTest/services/AxisService?wsdl";
String method="sum";
//返回值
RPCServiceClient serviceClient;
try {
serviceClient = new RPCServiceClient();
Options options = serviceClient.getOptions();
EndpointReference targetEPR = new EndpointReference(url);
options.setTo(targetEPR);
// 在创建QName对象时,QName类的构造方法的第一个参数表示WSDL文件的命名空间名,也就是<wsdl:definitions>元素的targetNamespace属性值
QName opAddEntry = new QName("http://service.Axis2Service",method);
Object[] opAddEntryArgs = new Object[] {"1","5"};
Class[] classes = new Class[] {String.class };
// 返回参数类型,这个和axis1有点区别
// invokeBlocking方法有三个参数,其中第一个参数的类型是QName对象,表示要调用的方法名;
// 第二个参数表示要调用的WebService方法的参数值,参数类型为Object[];
// 第三个参数表示WebService方法的返回值类型的Class对象,参数类型为Class[]。
// 当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new Object[]{}
// 如果被调用的WebService方法没有返回值,应使用RPCServiceClient类的invokeRobust方法,
// 该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同
Object[] result=serviceClient.invokeBlocking(opAddEntry,opAddEntryArgs, classes);
System.out.println(result[0].toString());
} catch (AxisFault e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
注意:上方代码第25行http://service.Axis2Service是在如下图位置获得的。
特别鸣谢:
网友:wangronaldo的分享:http://wangronaldo.iteye.com/blog/1456441
没有他的分享,我可能还在迷茫中,再次非常感谢。
由于博客限制(蛋疼的限制),我不能在此上传附件
请到此处下载源码:
http://download.csdn.net/detail/jsnh307/8815567