发布axis webservice教程

webservice教程  时间:2021-02-01  阅读:()

利用AXI S开发Webs ervic e(一)——如何发布自己的w ebs ervic e

先介绍下本人开发环境吧。 JDK 1.4.2+Myeclipse 6.0实在经不起诱惑尝尝鲜 +Tomcat

5.0.28+AXIS 1.4。 AXIS 1.4包可以在http://w s.apache.org/axis/找到。 假设所有的环境你已经搭好并且AXIS包也已经下好了。 OK Here we go~

解压axis-bin-1_4.zip这个包可以看到w ebapps 目录双击进入把里面的AXI S文件夹拷到 %TOMCAT_HOME%\webapps 目录下之后拷贝 activation.jar 、 mail.jar、 too ls.jar到%TOMCAT_HOME%\w ebapps\axis\WEB-INF\lib 目录下。 启动 tomc at  访问http://loc a lhos t:8080/ax is/happyax is.jsp如果访问成功恭喜你基本的配置你已经做完了。PS此处的%TOMCAT_HOME%指的是Tomc at的安装目录至于那另外的三个jar包 J2EE

1.4库里就能找的到。

现在来说一下最关键的Webs ervic e的发布。AXI S提供了两种发布方式一种是即时发布Instant Deployment另外一种是定制发布Custom Deployment。即时发布提供了一种非常简单的w ebs ervic e的发布方式但是其中限制太多因此在实际的开发中定制发布才是首选。这里也将会以定制发布为重点来介绍。

1.即时发布JWS (Java Web Service) Files - InstantDeployment

即时发布提供了一种非常简单发布方式发布者只要有Java源代码也就是.java文件然后把其后缀名改成 jws 也就是 java web service 的缩写 拷贝到%T OMCAT_HO ME%\w ebapps\axis 目录下即完成了所有的发布工作。AXI S的编译引擎会处理接下来的所有事情。下面是一段示例代码java代码public class HelloAXIS {public String Hello(String name){return"AXIS say hello to"+name;

}

}

把 HelloAXIS.java 文 件 改 成 HelloAXIS.jws 然 后 拷 贝到 %TOMCAT_HOME%\w ebapps\axis 目 录下  启 动 Tomc at 之后访 问http://localhost:8080/axis/HelloAXIS.jws如果能看到Click to see the WSDL这个超链接就说明已经发布成功了 点击进去就可以看到这个Webservic e的WSDL描述文件。 server端的

发布已经完成了接下来就是编写Client端测试代码了。java代码package c om.chnic.test;import java.net.URL;import javax.xml.namespac e.QName;import org.apache.axis.client.Call;import org.apache.axis.c lient.S ervic e;public class Test {public static void main(String[]args) throws Exception{

String targetEendPoint="http://loc alhost:8080/ax is/He llo AXI S.jw s";

Servic e s ervic e=new Servic e();

Call call=(Call) service.createCall();c all.s etOperationName(new QName(targetEendPoint, "Hello"));c all.s etTargetEndpointAddres s(new URL(targetEendPo int));

String result=(String) c all.invoke(new Object[]{"Robert"});

System.out.println(result);

}

}

测试代码很简单如果熟悉java反射机制的朋友不用两分钟就能看明白。运行后客户端控制台出现AXIS say hello Robert。测试成功。果然很简单吧。不过在这简单背后却是以牺牲灵活性为代价的。假如你现在手里只有.class或者一个jar包 jws就不再能满足你的需求了最要命的就是即时发布不支持带包的类这点AXI S的用户手册上写的也很明白。Important: JWS web services are intended for simple web services.You cannot use packages inthe pages, and as the code is compiled at run time you can not find out about errors until afterdeployment.Production quality web services should use Java classes with custom deployment.

2.定制发布Custom Deployment - Introducing WSDD

比起即时发布定制发布更加烦琐也更复杂但是换来的却是更大的灵活性因此在实际项目中定制发布还是不二的选择。定制发布需要你自己编写一个WSDDWeb ServiceDeployment Descriptor文件这个东东类似与XML稍后会做出介绍。废话不多说我们来看代码

java代码package c om.chnic.w ebs ervic e;public class HelloWorld{public HelloWorld(){

}public String hello(String str){r eturn"He l lo"+s tr;

}public int add(int a, int b){return a+b;

}

}

一个带包的很简单的类 在 eclipse 下编译后按照包名拷到%TOMCAT_HOME%\w ebapps\axis\WEB-INF\c las s es 目录下。 以这个类为例拷贝完之后 这 个 HelloWorld.class 的 路 径 就是%T OMCAT_HO ME%\w ebapps\axis\WEB-INF\c las s es\c om\c hnic\w ebs ervic e。 P S 如果嫌这样太麻烦可以另外建一个Java Web工程用myeclipse的发布工具发布到Tomcat之后整体一次性拷贝到w ebs eric ve的工程中。

接 下 来 就 需 要 编 写 发 布 文 件 deploy.wsdd 。到%TOMCAT_HOME%\w ebapps\axis\WEB-INF 目录下建立这个文件并在其中添加如下内容xml代码

<deployment xmlns=http://xm l.apache.org/axis/ws dd/xmlns:jav a="http://xml.apache.org/axis/w s dd/providers/java">

<service name="HelloWorld"provider="java:RPC">

<parameter name="clas sName"value="c om.chnic.webservic e.HelloWorld"/>

<parameter name="allowedMethods"value="*"/>

</s ervic e>

</dep loyment>

简单的介绍下各个节点的含义 "HelloWorld"当然是这个webservice的名字后面紧跟的javaRPC指的是服务类型。这里一共有有4种类型分别是RPC,Document,Wrapped

和Mes s age。有兴趣可以看下org.apache.axis.providers这个包和子包下面的类的API文档。之后的parameter节点第一个当然是指出具体的类第二个从字面上也很好理解允许调用的方法。这里的配置告诉引擎可以调用所有的public方法 当然你也可以自己指定。

编写完配置发布文件之后 cmd 打开 windows 的控制台 进入%T OMCAT_HO ME%\w ebapps\axis\WEB-INF目录下键入如下命令java-Djava.ext.dirs=lib org.apache.axis.c lient.Adm inClient dep loy.w sdd

之后控制台返回Processing file deploy.wsdd和Done processing这两段话即说明发布成功。此时会在同级目录生成一个s erver-c onfig.w s dd文件在这里的Admin C lient是AXI S提供的一个客户端管理工具。至于java.ext.dirs的含义可以去了解一下c las sloader和JVM类装载机制方面的知识在这里就不多解释。 还有一点要注意的是在发布的时候Tomc at服务必须处于启动状态否则就会抛出一堆无法连接的异常信息。发布成功之后你可以通过访问http://loc a lho s t:8080/ax is/s ervlet/Ax is S ervlet来查看你所有的定制发布的服务。

客户端测试代码

String targetEendPoint="http://loc alhost:8080/ax is/s ervic es/He lloWorld";

Servic e s ervic e=new Servic e();

Call call=(Call) service.createCall();c all.s etTargetEndpointAddres s(new URL(targetEendPo int));c all.setOperationName(new QName(targetEendPoint, "hello"));

String result=(String) c all.invoke(new Object[]{"Robert"});

System.out.println(result);c all.s etOperationN ame(new QName(targetEendPoint, "add"));

Integer res=(Integer)call.invoke(new Object[]{new Integer(1),new Integer(2)});

System.out.println("The result is: "+res);

运行测试代码控制台显示Hello Rob ert和The result is:3这两句话说明发布成功。仔细观察下发现其实除了那个targetEndpoint之外即时发布和定制发布的客户端调用代码基本上都是一样的。定制发布的URL可以在WSDL文件里找到。 其实定制发布还有一些高级特性这个就留到下一篇再说吧。

利用 AXIS开发Webservice(二)——WSDD的一些高级特性

1、取消发布一个webservice

开篇之前先把上篇的一个遗漏补充上上篇只讲了怎么发布一个w ebs ervic e但是如何取消没有却没有提。其实取消一个已经发布的w eb s ervc e也是非常简单的我们就拿上篇的HelloWorld来做例子吧。

发布webs ervic e的时候我们有一个deploy.w s dd文件 当然在取消发布的时候就会有一个undeploy.w s dd文件。这个文件的内容也很简单 xml的代码如下。

Xml代码

<undeployment xmlns="http://xm l.apac he.org/axis/w s dd/">

<service name="HelloWorld"/>

</undep loyment>

<undeployment xmlns="http://xm l.apac he.org/axis/w s dd/">

<service name="HelloWorld"/>

</undep loyment>

编写完这个xml文件之后把它同样c opy到%TOMCAT_HO M\w ebapps\axis\WEB-INF目录下然后CMD打开控制台在控制台输入一个我们很熟悉的命令java-Djava.ext.dirs=lib org.apache.axis.c lient.AdminClient undep loy.w sdd

运行之后得到如下结果说明取消发布成功

Processing file undeploy.wsdd

<Admin>Done processing</Admin>

2、WSDD的高级特性

说完取消发布之后就来说一下AXI S的一些高级特性AXI S在编写dep loy.w s dd这个文件时每个<s ervic e>节点下面会有这样一个子节点。

Xml代码

<parameter name="scope"value="value"/>

<parameter name=也就是你webservice服务的那个object在后面的value里可以有三个选项request, session, orapplic ation。熟悉Jsp、 Servlet、或者EJB里的Ses sionBean的朋友应该能很快能明白这个三个配置选项的含义。requst这个选项会让AXIS为每一个SOAP的请求产生一个服务对象可以想像如果这个webs ervice的对象足够复杂而且SOAP的请求过多这个选项是非常耗费服务器性能的。session如果选择了session程序就会给每个调用这个webservice的客户端创造一个服务对象。application这个选项最彪悍程序只会在内存里new出来一个服务对象然后为所有webs ervice客户端服务。很显然这个选项不能储存客户端的一些个性化数据。所以在功能性上很多时候不能满足要求。

3、高级特性Handler

接下来说一下Ax is的Handler和Chain机制Hand ler和Chain是Ax is引擎提供的一个很强大的工具。假如现在客户有这样一个需求需要记录某一个w ebs ervic e被调用的次数这个时候如果在service object里去实现这个功能不仅麻烦而且侵入了原有的程序也会对增加原有程序的不稳定性。有了Handler我们就能见easy的解决这个问题。我们先来编写handler的代码。

Java代码pac kage c om.chnic.handler;import org.apache.axis.AxisFault;import org.apache.axis.Mes sageContext;import org.apache.axis.handlers.BasicHandler;public class HelloWorldHandler extends Bas icHandler{private static final long serialVersionUID=1L;public void invoke(Mes sageContext c ontext) throws AxisFault {

String s tatus=(String) this.getOption("s tatus");

System.out.println("HelloWor ldHandler's status is: "+status);

}

}pac kage c om.chnic.handler;

import org.apache.axis.AxisFault;import org.apache.axis.Mes sageContext;import org.apache.axis.handlers.BasicHandler;public class HelloWorldHandler extends Bas icHandler{private static final long serialVersionUID=1L;public void invoke(MessageContext context) throws AxisFault {

String status=(String) this.getOption("status");

System.out.println("HelloWorldHandler's status is: "+status);

}

}

BasicHandler是一个抽象类 Axis提供了很多Handler的具体实现 Basic Handler只是其中最简单的一个。要实现一个自己的handler首先要从继承Bas ic Handler这个类开始并实现其中的invoke(Mes sageContext arg)这个方法。Mes sageContext可以看成是一个Axis的上下文里面存储的是一些Ax is和w eb s ervic e的基本信息。想了解的朋友可以看一下Axis的API。编写完Handler代码之后我们连编写发布文件。

Xml代码

<deployment xmlns="http://xm l.apache.org/axis/w s dd/"xmlns:java="http://xml.apache.org/axis/w s dd/providers/java">

<handler name="Hello" type="j ava:c om.chnic.handler.HelloWorldHandler">

<parameter name="status"value="succ ess"/>

</handler>

<service name="HelloWorld"provider="java:RPC">

<requestFlow>

<handler type="He llo"/>

</requestFlow>

<parameter name="clas sName"value="c om.chnic.webservic e.HelloWorld"/>

<parameter name="allowedMethods"value="*"/>

<parameter name="scope"value="session"/>

</s ervic e>

</dep loyment>

发布代码中有这样的一句细心的朋友一定会发现。

Xml代码

<parameter name="status"value=" session"/>

<parameter name="status"value=" session"/>看完这句代码再对比一下Handler的实现代码中的一句相信大多数人都能明白了。

Java代码

String status=(String) this.getOption("status");

String status=(String) this.getOption("status");Handler通过getOption(String)这个方法拿到了配置文件中我配置的属性值。而我们上述所做的所有工作对于原来的Webs erivc e来说都是透明的不会对侵入原有的程序当中。 一个Handler可以被多个s ervic e所使用通过<requestFlow>这个标签来引用到某一个servic e 中这里还要多提一句既然是一个requestFlow这个当然可以加不只一个的Handler。接下来编写测试代码运行。在本地应用服务器上会打出如下语句HelloWorldHandler's status is: session说明测试成功而且handler是配置在requestflow标签中所以这段代码会在service代码之前先执行。

4、高级特性Chain

介绍完了Handler再来介绍Chain。从Chain的字面意思就能猜到他实现的一连串Handler的功能。假如某个s ervice需要不止一个Handler或者要根据Client的情况来选择需要那些Handler。特别是后一个需求我们无法用一个或者几个Handler来解决这个时候我们就需要<Chain>来实现了。我们先再编写一个Handler加上之前的那个Handler我们来组成一条锁链。

Java代码pac kage c om.chnic.handler;import org.apache.axis.AxisFault;import org.apache.axis.Mes sageContext;import org.apache.axis.handlers.BasicHandler;public class MyHandler extends Bas icHandler {private static final long serialVersionUID=1L;public void invoke(Mes sageContext c ontext) throws AxisFault {

System.out.println("This is MyHandler. .");

}

}

之后我们编写Chain的代码

Java代码package c om.chnic.chain;import org.apache.axis.SimpleChain;import c om.chnic.handler.He lloWor ldHandler;import c om.chnic.handler.MyHandler;public clas s HelloWorldChain extends Simp leChain{private static final long serialVersionUID=1L;public HelloWorldChain(){

HelloWorldHandler hwh=new HelloWorldHandler();

MyHandler mh=new MyHandler();this.addHandler(hw h);this.addHandler(mh);

}

}

在Chain的构造函数中把我要的两个Hand ler用addHand ler()方法加载进去。之后我们来编写发布文件。 <c hain>和<handler>元素有些许不同在这里有必要多句嘴。

<chain>元素中的子元素只允许是<handler>或者<chain>。后者也就是允许在“锁链”里再嵌套“锁链”在这里就拿嵌套<handler>来举例他同样有两种方式来实现。第一种是直接包含<handler>:

Xml代码

<chain name="myChain">

<handler type="java:c om.chnic.handler.MyHandler"/>

</chain>

<chain name="myChain">

<handler type="java:c om.chnic.handler.MyHandler"/>

</c hain>

第二种是引用别的<handler>

Xml代码

<handler name="myHandler" type="jav a:c om.chnic.handler.MyHandler"/>

<chain name="myChain"/>

<handler type="myHand ler"/>

</chain>

因为我们这里的Handler并没有由Bas icHandler来实现而是由继承S impleChain这个类来实现严格意义上讲 S imp leChain也可以算是一个Handler 因为Simp leCh ain也是从BasicHandler继承而来他同样实现了invoke()这个方法。下面回归正题来看我们的发布代码。

Xml代码

<deployment xmlns="http://xm l.apache.org/axis/w s dd/"xmlns:java="http://xml.apache.org/axis/w s dd/providers/java">

<chain name="myChain">

<handler type="java:c om.chnic.chain.He lloWorldChain"/>

</c hain>

酷番云78元台湾精品CN2 2核 1G 60G SSD硬盘

酷番云怎么样?酷番云就不讲太多了,介绍过很多次,老牌商家完事,最近有不少小伙伴,一直问我台湾VPS,比较难找好的商家,台湾VPS本来就比较少,也介绍了不少商家,线路都不是很好,有些需求支持Windows是比较少的,这里我们就给大家测评下 酷番云的台湾VPS,支持多个版本Linux和Windows操作系统,提供了CN2线路,并且还是原生IP,更惊喜的是提供的是无限流量。有需求的可以试试。可以看到回程...

阿里云年中活动最后一周 - ECS共享型N4 2G1M年付59元

以前我们在参与到云服务商促销活动的时候周期基本是一周时间,而如今我们会看到无论是云服务商还是电商活动基本上周期都要有超过一个月,所以我们有一些网友习惯在活动结束之前看看商家是不是有最后的促销活动吸引力的,比如有看到阿里云年中活动最后一周,如果我们有需要云服务器的可以看看。在前面的文章中(阿里云新人福利选择共享性N4云服务器年79.86元且送2月数据库),(LAOZUO.ORG)有提到阿里云今年的云...

justhost:“第4次VPS测评”,8.3元/月,200M带宽,不限流量,KVM虚拟,4个俄罗斯机房应有适合你的

justhost.ru官方来消息说已经对网络进行了比较全面的优化,针对中国电信、联通、移动来说,4个机房总有一个适合中国用户,让站长进行一下测试,这不就有了这篇有关justhost的VPS的第四次测评。本帖主要关注的是网络,对于其他的参数一概不管! 官方网站:https://justhost.ru 最低配VPS:8.3元/月,KVM,512M内存,5G硬盘,200M带宽,不限流量 购买链接:...

webservice教程为你推荐
视频制作软件哪个好哪款视频编辑软件比较好用?聚酯纤维和棉哪个好聚酯纤维和棉哪个好ps软件哪个好PS哪一款软件比较好用呢核芯显卡与独立显卡哪个好核芯显卡和独立显卡哪个好?请直接点谢谢啦!网校哪个好请问在网校排名中,哪个网校是最好的?想找一家最好的来选择啊?qq空间登录电脑手机上怎么登陆电脑版QQ空间飞信空间登录请问如何登陆我的飞信空间?东莞电信宽带东莞电信光纤宽带包月费用多少 个人公司家用宽带办理网通dns服务器地址中国联通的默认DNS是多少360云盘同步版360云盘和360云盘同步版有甚么区分同步版占用电脑空间?
海外域名 虚拟主机管理软件 虚拟主机提供商 域名升级访问 免费申请网站域名 冰山互联 cdn服务器 京东云擎 php探针 e蜗牛 1g内存 上海电信测速网站 国外网页代理 双十二促销 免备案jsp空间 nnt 美国asp空间 winserver2008 美国代理服务器 百度新闻源申请 更多