转:http://blog.csdn.net/lixj2009/article/details/4752721
首先到apache的网站下载axis的开发包,好久没看了,现在已经开始出2.0的啦,不过好像还不是很成熟,这里,我们还是用1.x的包。最新的是1.4的包。
一、服务器端开发
首先编写服务端程序,这时我们完全不用考虑他是不是当作webservcies来发布的,因为在写法上没有什么不同。比如我们写了一个很简单的java程序,代码如下:
package com.service; public class Calculator { public int add(int i1,int i2) { System.out.println("调用add方法"); return i1 + i2; } public int subtract(int i1,int i2) { System.out.println("调用subtract方法"); return i1 - i2; } }
如果我们要把他发布成为services,首先需要把axis-1_3下的lib文件复制到我们的web服务的web-inf 的lib下。 然后在web.xml里增加以下内容
<?xml version="1.0" encoding="UTF-8"?> <deployment name="defaultClientConfig" xmlns:java="http://xml.apache.org/axis/wsdd/providers/java" xmlns:handler="http://xml.apache.org/axis/wsdd/providers/handler" xmlns="http://xml.apache.org/axis/wsdd/"> <globalConfiguration name="defaultClientConfig"> <requestFlow name="RequestFlow1" type=""> <handler name="Handler1" type="java:org.apache.axis.handlers.JWSHandler"> <parameter name="scope" value="session" /> </handler> <handler name="Handler2" type="java:org.apache.axis.handlers.JWSHandler"> <parameter name="scope" value="request" /> <parameter name="extension" value=".jwr" /> </handler> </requestFlow> </globalConfiguration> <handler name="URLMapper" type="java:org.apache.axis.handlers.http.URLMapper" /> <handler name="LocalResponder" type="java:org.apache.axis.transport.local.LocalResponder" /> <handler name="Authenticate" type="java:org.apache.axis.handlers.SimpleAuthenticationHandler" /> <transport name="http" type=""> <requestFlow name="RequestFlow1" type=""> <handler name="Handler1" type="URLMapper" /> <handler name="Handler2" type="java:org.apache.axis.handlers.http.HTTPAuthHandler" /> </requestFlow> </transport> <transport name="local" type=""> <responseFlow name="ResponseFlow1" type=""> <handler name="Handler1" type="LocalResponder" /> </responseFlow> </transport> <service name="Calculator" type="" provider="java:RPC" style="rpc" use="encoded"> <parameter name="scope" value="Request" /> <parameter name="className" value="com.service.Calculator" /> <parameter name="allowedMethods" value="*" /> <namespace>http://example2.userguide.samples</namespace> </service> </deployment>
其中要发布的每个service都需要加上一个service的节点描述,其他多余的servie节点可以删除的,这样重启tomcat后,我们就可以以http://localhost:8080/services/Calculator 来访问这个service了,同样以http://localhost:8080/services/Calculator?wsdl 访问到它的wsdl描述文件。
二、客户端开发
在开发工具中引进lib下的jar包;然后编写客户端程序
package com.client; import org.apache.axis.client.Call; import org.apache.axis.client.Service; import org.apache.axis.encoding.XMLType; import javax.xml.rpc.ParameterMode; public class Calcclient { public static void main(String[] args) throws Exception { try { //String endpoint = "https://localhost:8440/services/Calculator"; String endpoint = "http://127.0.0.1:8090/axisService/services/Calculator"; Integer i1 = new Integer(1); Integer i2 = new Integer(2); Service service = new Service(); Call call = (Call) service.createCall(); call.setTargetEndpointAddress(new java.net.URL(endpoint)); call.setoperationName("add");//调用方法的名字 call.addParameter("i1",XMLType.XSD_INT,ParameterMode.IN); call.addParameter("i2",ParameterMode.IN); call.setReturnType(XMLType.XSD_INT); Integer ret = (Integer) call.invoke(new Object[] { i1,i2 }); System.out.println("Got result : " + ret); } catch (Exception e) { e.printstacktrace(); } } }
其中 setoperationName就是指定执行的方法,addParameter就是指定参数
运行一下吧,结果:
Got result : 3
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。