利用Apache AXIS 1 发布WebService

首先,AXIS 是apache的作品。


1.到apache去下载相关的包,包括axis.jar、axis-ant.jar、commons-discovery-0.2.jar等。将jar包放到WEB-INF/lib下面



2.在WEB.XML中按如下配置,直接copy进去就可以

  1. <servlet>
  2. <servlet-name>AxisServlet </servlet-name>
  3. <servlet-class>
  4. org.apache.axis.transport.http.AxisServlet
  5. </servlet-class>
  6. </servlet>
  7. <servlet>
  8. <servlet-name>AdminServlet </servlet-name>
  9. <servlet-class>
  10. org.apache.axis.transport.http.AdminServlet
  11. </servlet-class>
  12. <load-on-startup>100 </load-on-startup>
  13. </servlet>
  14. <servlet>
  15. <servlet-name>SOAPMonitorService </servlet-name>
  16. <servlet-class>
  17. org.apache.axis.monitor.SOAPMonitorService
  18. </servlet-class>
  19. <init-param>
  20. <param-name>SOAPMonitorPort </param-name>
  21. <param-value>5001 </param-value>
  22. </init-param>
  23. <load-on-startup>100 </load-on-startup>
  24. </servlet>
  25. <servlet-mapping>
  26. <servlet-name>AxisServlet </servlet-name>
  27. <url-pattern>/servlet/AxisServlet </url-pattern>
  28. </servlet-mapping>
  29. <servlet-mapping>
  30. <servlet-name>AxisServlet </servlet-name>
  31. <url-pattern>*.jws </url-pattern>
  32. </servlet-mapping>
  33. <servlet-mapping>
  34. <servlet-name>AxisServlet </servlet-name>
  35. <url-pattern>/services/* </url-pattern>
  36. </servlet-mapping>
  37. <servlet-mapping>
  38. <servlet-name>SOAPMonitorService </servlet-name>
  39. <url-pattern>/SOAPMonitor </url-pattern>
  40. </servlet-mapping>

3.创建一个webservice类,就是一个普通的类包含一个普通方法


  1. public class SayHello {
  2. public String hello(String name){
  3. return "Hello "+name;
  4. }
  5. public void in(String name){
  6. System.out.println(name + "come");
  7. Log4j.getLogger().info(name + "come");
  8. }
  9. }

4.配置server-config.wsdd,server-config.wsdd的路径在WEB-INF下面,参考第一张图。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <deployment name="defaultClientConfig"
  3. xmlns= "http://xml.apache.org/axis/wsdd/"
  4. xmlns:java= "http://xml.apache.org/axis/wsdd/providers/java"
  5. xmlns:handler= "http://xml.apache.org/axis/wsdd/providers/handler">
  6. <globalConfiguration>
  7. <parameter name="disablePrettyXML" value="true"/>
  8. <parameter name="dotNetSoapEncFix" value="true"/>
  9. <parameter name="enableNamespacePrefixOptimization" value="false"/>
  10. <requestFlow>
  11. <handler type="java:org.apache.axis.handlers.JWSHandler">
  12. <parameter name="scope" value="session"/>
  13. </handler>
  14. <handler type="java:org.apache.axis.handlers.JWSHandler">
  15. <parameter name="scope" value="request"/>
  16. <parameter name="extension" value=".jwr"/>
  17. </handler>
  18. <!-- uncomment this if you want the SOAP monitor -->
  19. <!--
  20. <handler type="java:org.apache.axis.handlers.SOAPMonitorHandler"/>
  21. -->
  22. </requestFlow>
  23. <!-- uncomment this if you want the SOAP monitor -->
  24. <!--
  25. <responseFlow>
  26. <handler type="java:org.apache.axis.handlers.SOAPMonitorHandler"/>
  27. </responseFlow>
  28. -->
  29. </globalConfiguration>
  30. <handler type="java:org.apache.axis.handlers.http.URLMapper" name="URLMapper"/>
  31. <handler type="java:org.apache.axis.transport.local.LocalResponder" name="LocalResponder"/>
  32. <handler type="java:org.apache.axis.handlers.SimpleAuthenticationHandler" name="Authenticate"/>
  33. <service name="AdminService" provider="java:MSG">
  34. <namespace>http://xml.apache.org/axis/wsdd/ </namespace>
  35. <parameter name="allowedMethods" value="AdminService"/>
  36. <parameter name="enableRemoteAdmin" value="false"/>
  37. <parameter name="className" value="org.apache.axis.utils.Admin"/>
  38. </service>
  39. <service name="Version" provider="java:RPC">
  40. <parameter name="allowedMethods" value="getVersion"/>
  41. <parameter name="className" value="org.apache.axis.Version"/>
  42. </service>
  43. <!-- ======================以上内容一般不需要修改===========================-->
  44. <!-- ======================================================================
  45. Services:Demo,此段包含Sevice配置实例
  46. =======================-->
  47. <!--
  48. 示例1: 简单 Service
  49. 情境: 包含下例代码中基本属性.所有参数传递均为元数据,即int、float、double、String、boolean等非对象数据;
  50. 可以访问此Service中所有的方法
  51. 引用: 在C#中借助于IDE引用。
  52. -->
  53. <service name="WSTest1" provider="java:RPC"> <!-- name: 此WebService的名称;provider:工作模式 -->>
  54. <parameter name="className" value=" org.tp.SayHello "/> <!-- 此Service对应的实现类 -->
  55. <parameter name="allowedMethods" value="*"/> <!-- 可以访问这个Service中所有的方法 -->
  56. </service>
  57. <!-- ======================以下内容一般不需要修改===========================-->
  58. <transport name="http">
  59. <parameter name="qs:list"
  60. value= "org.apache.axis.transport.http.QSListHandler"/>
  61. <parameter name="qs:method"
  62. value= "org.apache.axis.transport.http.QSMethodHandler"/>
  63. <parameter name="qs:wsdl"
  64. value= "org.apache.axis.transport.http.QSWSDLHandler"/>
  65. <requestFlow>
  66. <handler type="URLMapper"/>
  67. <handler type="java:org.apache.axis.handlers.http.HTTPAuthHandler">
  68. </handler>
  69. </requestFlow>
  70. </transport>
  71. <transport name="local">
  72. <responseFlow>
  73. <handler type="LocalResponder"/>
  74. </responseFlow>
  75. </transport>
  76. </deployment>

配置文件中有的东西不固定,在文件注释中描述得很清楚。针对第二步中的类,我们只看配置中的示例1,其中红色标记部分是实现类的路径,注意校正就OK。


5.这样一个最基本的webservice就布好了,运行服务器(本例中是tomcat 6)。在地址栏中输入

http://127.0.0.1:8080/appName/services

注意校正URL,services是固定的。

运行后会列出本应用服务器上发布的webservice

点我们刚才那个 WSTest1,会出现


当别人引用webservice时,一般是用http://localhost:8080/DemoLanZhou/services/WSTest1?wsdl这个地址来引用的


6.开着服务器,等着别人来引用。

也可以在浏览器测试一下http://localhost:8080/DemoLanZhou/services/WSTest1?method=hello&args=tp

注意校正地址,参数中method=hello表示调用hello方法,args=tp是传给hello方法的参数。hello方法就是SayHello.hello();最上面定义的那个类。

上图中选中部分为方法返回的值。


至此完成一个基本的webservice。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值