1:首先下载Axis开发组件(我这里说的不是axis2,是axis注意)
如果要在自己的test测试项目中加入axis的支持,那么只需要到web.xml增加下面内容即可。
<listener>
<listener-class>
org.apache.axis.transport.http.AxisHTTPSessionListener
</listener-class>
</listener>
<servlet>
<servlet-name>AxisServlet</servlet-name>
<display-name>Apache-Axis Servlet</display-name>
<servlet-class>
org.apache.axis.transport.http.AxisServlet
</servlet-class>
</servlet>
<servlet>
<servlet-name>AdminServlet</servlet-name>
<display-name>Axis Admin Servlet</display-name>
<servlet-class>
org.apache.axis.transport.http.AdminServlet
</servlet-class>
<load-on-startup>100</load-on-startup>
</servlet>
<servlet>
<servlet-name>SOAPMonitorService</servlet-name>
<display-name>SOAPMonitorService</display-name>
<servlet-class>
org.apache.axis.monitor.SOAPMonitorService
</servlet-class>
<init-param>
<param-name>SOAPMonitorPort</param-name>
<param-value>5001</param-value>
</init-param>
<load-on-startup>100</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>AxisServlet</servlet-name>
<url-pattern>/servlet/AxisServlet</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>AxisServlet</servlet-name>
<url-pattern>*.jws</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>AxisServlet</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
注意加入对应的axis的jar包
启动自己的项目工程,如果没有错误,你可以输入地址
http://locahost:8080/项目名/services 查询所有发布的webservice应用
如果你建立的项目发布到tomcat中叫test那么就访问 http://localhost:8080/test/services
你会看到
And now... Some Services
上面是axis自己发布的默认服务。
那么我们怎么发布自己的webservice应用呢?
自己写一个java文件
package com.test.tec.axis;
public class TestService {
public String sayHello(){
System.out.println("hello world");
return "hello world";
}
public String sayHello2(){
System.out.println("hello world");
return "hello world";
}
}
那么怎么发布这个服务呢?首先我们需要借组axis的工具 org.apache.axis.client.AdminClient 这个在axis.jar包中
使用它你必须先启动tomcat,比如我把我们的项目发布到tomcat的webapp中,名叫test,
test项目的目录结构如下:
--META-INF
--WEB-INF
-classes
-lib
-web.xml
发布自己的webservice服务,分下面几步:
1:可以先写一个wsdd文件,这个文件你可以自己写,格式很简单(该文件写在WEB-INF目录下)
<deployment xmlns="http://xml.apache.org/axis/wsdd/" xmlns:java="http://xml.apache.org/axis/wsdd/providers/java"> <service name="TestService" provider="java:RPC"> <parameter name="className" value="com.test.tec.axis.TestService"/> <parameter name="allowedMethods" value="*"/> </service></deployment>
主要就是service的写法,name就是名字,随便起,后面的provider就是告诉这个webservice是通过RPC调用的
后面的参数就是告诉这个java的类地址,后面allowedmethods就是说发布所有方法(*)
写好以后,把你的工程test发布到tomcat的webapp下。
2:确定你启动好了tomcat,确认没有错误后,那么在命令行cmd模式下输入命令:
先转到tomcat的webapp目录,例如我的tomcat在D:\Tomcat5_Test\webapps\test\WEB-INF
那么就是 cd D:\Tomcat5_Test\webapps\test\WEB-INF
D:
下面就转入到我的WEB-INF目录了,测试写入命令
D:\Tomcat5_Test\webapps\test\WEB-INF>java -Djava.ext.dirs=lib org.apache.axis.cl ient.AdminClient -lhttp://localhost:8080/test/servlet/AxisServlet deploy.wsdd
注意,后面的java.ext.dirs=lib就是告诉命令到当前目录WEB-INF下的lib包里找到对应的执行类AdminiClient
后面-l 是代表location地址,-l后面紧接着(没有空格)就是你的webservice发布文件,写法是
应用地址:http://localhost:8080/test/ 加指定格式servlet/AxisServlet 即可,wsdd就是你要发布的文件
回车上面命令,如果出现:
Processing file deploy.wsdd <Admin>Done processing</Admin>
如果你嫌弃上面使用cmd麻烦,你可以写bat文件
在WEB-INF建立了个批处理文件,方便以后发布:
set Axis_Lib=D:\Tomcat5_Test\webapps\test\WEB-INF\lib
set Java_Cmd=java -Djava.ext.dirs=%Axis_Lib%
set Axis_Servlet=http://localhost:8080/test/servlet/AxisServlet-----------这个http://localhost:8080/前缀根据你的应用来改
%Java_Cmd% org.apache.axis.client. AdminClient -l%Axis_Servlet% deploy.wsdd(这个是你发布的wsdd文件名)
恭喜你成功了,你此时再次访问:
http://localhost:8080/test/services 是不是对了一个服务?
And now... Some Services
AdminService (wsdl)
AdminService
Version (wsdl)
getVersion
TestService (wsdl)
sayHello
sayHello2
而且你的WEB-INF目录下多了一个文件server-config.wsdd 这个文件就是部署描述文件,你复制下来,放到你的工程test的WEB-INF目录下,这样你再次发布你的test工程的时候就不需要在去发布原来已经发布过的webservice应用了。
每次你发布新的ws,axis都会更新这个server-config.wsdd文件。
附件是axis用到的包,不知道是否有遗漏呢?应该没吧。
发布好以后,我们客户端怎么去调用呢?
1:你可以直接写方法去调用,例如:
public static void callWsMethod(){
Service s = new Service();
Call call = null;
try {
call = (Call)s.createCall();
call.setTargetEndpointAddress("http://localhost:8080/test/services/VersionService?wsdl");
call.setReturnType(XMLType.SOAP_STRING);
String s_resp = (String)call.invoke("printVersion", null);
System.out.println("执行结果:" + s_resp);
} catch (ServiceException e) {
e.printStackTrace();
} catch (RemoteException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
2:如果遇到复杂的webservice方法,那么你可能需要使用工具帮你自动生成java代码,也就是根据wsdl文件生成java,axis提供这样的工具 org.apache.axis.wsdl.WSDL2Java -o codetest ,-d Session -S true myservice.wsdl 命令会在当前目录下建立一个codetest 文件夹存放生成的java文件
首先我们把http://localhost:8080/test/services/VersionService?wsdl 另存为 myservice.wsdl文件,注意后缀名
然后把文件放到tomcat的webapps工程test目录WEB-INF下
通过cmd命令输入:
D:\Tomcat5_Test\webapps\test\WEB-INF>java -Djava.ext.dirs=lib org.apache.axis.ws
dl.WSDL2Java -o codetest -d Session -S true myservice.wsdl
运行后会多出一个目录codetest 下面就是生成的客户端调用的java类
主要看 *SoapBindingImpl.java 和*ServiceLocator.java *Service.java 3个java文件,最后一个是接口,
impl是实现类,你可以看到里面的方法都是webservice发布的方法,都return null,说明需要你去实现
例如我的例子里的:
public java.lang.String getVersion() throws java.rmi.RemoteException {
return null;
}
那么我这样实现
public java.lang.String getVersion() throws java.rmi.RemoteException {
*ServiceLocator locator = new *ServiceLocator();
*Service service;
try {
service = locator.get*Service();
return service.getVersion();
} catch (ServiceException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
这样就可以测试调用的结果了!
参考网址:
http://ws.apache.org/axis/java/user-guide.html#WSDL2JavaBuildingStubsSkeletonsAndDataTypesFromWSDL