一、 服务器端的配置及发布
1 配置Axis2的环境:
1.1 我们可以到http://ws.apache.org/axis2/下载Axis2的最新版,可以下载两个zip包: axis2-1.5.4-bin.zip和 axis2-1.5.4-war.zip。
1.2 其中axis2-1.5.4-bin.zip文件中包含了Axis2中所有的jar文件,axis2-1.5.4-war.zip文件用于将WebService发布到Web容器中。
1.3 将axis2-1.5.4-war.zip文件解压到相应的目录,将目录中的axis2.war文件放到<Tomcat安装目录>\webapps目录中,并启动Tomcat,在浏览器地址栏中输入如下的URL:http://localhost:8080/axis2/,如看到axis2的主页面则安装成功。
图 1-1
2使用Axis2不打包发布WebService其基本步骤(适合调试):
2.1 新建工程及需要发布的WebService接口类和其方法实现,并导入Axis2所需jar包;
<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-name>AxisServlet</servlet-name>
<url-pattern>/services/*</url-pattern>
代码示例 1
2.3 把tomcat安装目录下的webapps/axis2/WEB-INF下的modules、services和conf文件拷至项目的WEB-INF目录下,及jar包拷贝;
2.4 然后再services目录下新建:类名/meta-inf路径,meta-inf下新建services.xml;
<servicename="SimpleService">
<!-- 对接口的描述、注释 -->
<description>
SimpleService Service
</description>
<!--调用接口所在的类路径 -->
<parametername="ServiceClass">
com.service.SimpleService
</parameter>
<!--
指定方法:
如果该方法有返回值则需要使用可处理输入输出的RPcmessageReceiver类;
如果该方法没有返回值则需要使用只能处理输入的RPCInOnlyMessageReceiver类。
访问:http://localhost:8080/webservice/services/SimpleService?wsdl
-->
<operationname="getPersonjsONArr">
<messageReceiverclass="org.apache.axis2.rpc.receivers.RPcmessageReceiver"/>
</operation>
</service>
代码示例 2
如果想发布多个WebService,可以使用<serviceGroup>元素:
<serviceGroup>
<service name="myService1">
…
</service>
<service name="myService2">
…
</service>
</serviceGroup>
代码示例 3
2.5 启动tomcat服务器访问http://localhost:8080/项目访问名称 /services/类名?wsdl。如能看到wsdl的xml服务信息,则说明发布成功。
图 1-2
3打包发布WebService其基本步骤(适合发布):
3.1新建工程及需要发布的WebService接口类和其方法实现;
3.2 在工程下新建文件夹services/SimpleService(一般为类名),然后在SimpleService文件夹下按SimpleService.java类所在包的路径创建对应的文件夹,例如com /service,最后将编译后的SimpleService.class拷入com/ service下。
图 1-3
3.3SimpleService文件夹下在新建文件夹meta-inf,meta-inf下新建services.xml(内容同2.4一样) 。
3.4 最后在Windows命令行下进到services/SimpleService目录下运行:jar cvf SimpleService.aar .(最后有个点号),会在SimpleService目录下生成SimpleService.aar包 (也可安装Axis2的axis2 service archiver插件生成该.aar包)。如果在发布的webService中引用了jar或其它类文件,则需将jar放到*\axis2\WEB-INF\lib中,或是将引用类的.class文件放到*\axis2\WEB-INF\classes中(压缩成.jar放至lib中也可)。
3.5 把SimpleService.aar拷入tomcat安装目录下的webapps/axis2/WEB-INF/services下,再进入http://localhost:8080/axis2/进入Services就会看到SimpleService了。
二、 客户端的调用
1)、应用rpc的方式调用WebService
这种方式就等于远程调用,即通过url定位告诉远程服务器,告知方法名称,参数等,调用远程服务得到结果,调用前先导入相应Axis2的jar包。
//使用RPC方式调用WebService
RPCServiceClient client =new RPCServiceClient();
Options options = client.getoptions();
//访问地址
String address ="http://ip地址:端口/项目名/services/ws服务名";
//指定调用WebService的URL
EndpointReference epf =new EndpointReference(address);
options.setTo(epf);
QName qName=new QName("wsdl中命名空间targetNameSpace属性值","方法名");
/* invokeBlocking方法有三个参数:
第二个参数表示要调用的WebService方法的参数值,参数类型为Object[];
第三个参数表示WebService方法的返回值类型的Class对象,参数类型为Class[]。
当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new
Object[]{}。
如果被调用的WebService方法没有返回值,应使用RPCServiceClient类的invokeRobust方法,
该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同
*/
Object[] result = client.invokeBlocking(qName,new Object[] {”abc” },new Class[] {String.class});
//接收返回的结果
String resultStr = result[0].toString();
代码示例 4
2)、使用wsdl2java生成客户端来调用WebService。
Axis2提供了一个wsdl2java.bat命令可以根据WSDL文件自动产生调用WebService的代码。wsdl2java.bat命令可以在<Axis2安装目录>/bin目录中找到。在使用 wsdl2java.bat命令之前需要设置AXIS2_HOME环境变量,该变量值是<Axis2安装目录>。
在Windows控制台输出如下的命令行来生成调用WebService的代码:
%AXIS2_HOME%\bin\wsdl2java
-urihttp://localhost:8080/ws/services/SimpleService?wsdl -p client -s -o stub
代码示例 5
其中-url参数指定了wsdl文件的路径,可以是本地路径,也可以是网络路径。
-p参数指定了生成的java类的包名,-o参数指定了生成的一系列文件保存的根目录。在执行完上面的命令后,就会发现在当前目录下多了个stub目录,在stub/src/client目录可以找到一个HelloServiceStub.java文件,该文件复杂调用WebService,可以在程序中直接使用这个类(也可安装Axis2的axis2 code generator插件生成stub客户端类)。
代码示例如下:
//创建stub客户端对象
SimpleServiceStubstub =newSimpleServiceStub();
SimpleServiceStub.GetPersonjsONArrgetPersonjsONArr =new SimpleServiceStub.GetPersonjsONArr();
//传递参数
getPersonjsONArr.setPersonjsONArr("***");
Stringstr = stub.getPersonjsONArr(getPersonjsONArr).get_return();
代码示例 6
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。