读书人

开发人员应当知道的webservice知识

发布时间: 2012-08-11 20:50:31 作者: rapoo

开发人员应该知道的webservice知识

为什么说说webservice呢?

如今soa炒得火热,各大公司招聘都在要求懂soa技术,虽然大的概念是面向架构服务,说白了就是服务整合,把以前的老应用跟新应用通信,实现应用集成。具体实现技术为webservice。


webservice是什么?

webservice 提供的接口传递数据格式借助xml数据包传递的,基于soap对象访问协议,并且请求都遵行http协议,由于每中语言,对xml 数据包都遵行这一规则,这就提供了,不同开发平台下、不同系统的接口调用与访问。


规则与协议:

1.XML:描述数据的标准方法.

  2.SOAP:简单对象访问协议.  3.WSDL:Web服务描述语言.  4.UDDI(Universal Description, Discovery and Integration):通用描述、发现与集成,它是一种独立于平台的,基于XML语言的用于在互联网上描述商务的协议。


webservice实现方式(转自:http://blog.163.com/yexuan_1/blog/static/13436609920121833513679/):

一、利用jdk web服务api实现,这里使用基于 SOAP message 的 Web 服务
1.首先建立一个Web services EndPoint:

开发人员应当知道的webservice知识package Hello;
开发人员应当知道的webservice知识import javax.jws.WebService;
开发人员应当知道的webservice知识import javax.jws.WebMethod;
开发人员应当知道的webservice知识import javax.xml.ws.Endpoint;
开发人员应当知道的webservice知识
开发人员应当知道的webservice知识@WebService
开发人员应当知道的webservice知识public class Hello {
开发人员应当知道的webservice知识
开发人员应当知道的webservice知识@WebMethod
开发人员应当知道的webservice知识public String hello(String name) {
开发人员应当知道的webservice知识return "Hello, " + name + "\n";
开发人员应当知道的webservice知识}
开发人员应当知道的webservice知识
开发人员应当知道的webservice知识 public static void main(String[] args) {
开发人员应当知道的webservice知识 // create and publish an endpoint
开发人员应当知道的webservice知识 Hello hello = new Hello();
开发人员应当知道的webservice知识 Endpoint endpoint = Endpoint.publish("http://localhost:8080/hello", hello);
开发人员应当知道的webservice知识 }
开发人员应当知道的webservice知识}
开发人员应当知道的webservice知识 2.使用 apt 编译 Hello.java(例:apt -d [存放编译后的文件目录] Hello.java ) ,会生成 jaws目录
3.使用java Hello.Hello运行,然后将浏览器指向http://localhost:8080/hello?wsdl就会出现下列显示
开发人员应当知道的webservice知识
4.使用wsimport 生成客户端

使用如下:wsimport -p . -keep http://localhost:8080/hello?wsdl

这时,会在当前目录中生成如下文件:
开发人员应当知道的webservice知识
5.客户端程序:
1开发人员应当知道的webservice知识class HelloClient{
2开发人员应当知道的webservice知识public static void main(String args[]) {
3开发人员应当知道的webservice知识 HelloService service = new HelloService();
4开发人员应当知道的webservice知识 Hello helloProxy = service.getHelloPort();
5开发人员应当知道的webservice知识 String hello = helloProxy.hello("你好");
6开发人员应当知道的webservice知识 System.out.println(hello);
7开发人员应当知道的webservice知识 }
8开发人员应当知道的webservice知识}
9开发人员应当知道的webservice知识
以上方法还稍显繁琐,还有更加简单的方法

二、使用xfire,我这里使用的是myeclipse集成的xfire进行测试的
利用xfire开发WebService,可以有三种方法:
1一种是从javabean 中生成;
2 一种是从wsdl文件中生成;
3 还有一种是自己建立webservice
步骤如下:
用myeclipse建立webservice工程,目录结构如下:
开发人员应当知道的webservice知识
首先建立webservice接口,
代码如下:

1开发人员应当知道的webservice知识package com.myeclipse.wsExample;
2开发人员应当知道的webservice知识//Generated by MyEclipse
3开发人员应当知道的webservice知识
4开发人员应当知道的webservice知识public interface IHelloWorldService {
5开发人员应当知道的webservice知识
6开发人员应当知道的webservice知识 public String example(String message);
7开发人员应当知道的webservice知识
8开发人员应当知道的webservice知识} 接着实现这个借口: 1开发人员应当知道的webservice知识package com.myeclipse.wsExample;
2开发人员应当知道的webservice知识//Generated by MyEclipse
3开发人员应当知道的webservice知识
4开发人员应当知道的webservice知识public class HelloWorldServiceImpl implements IHelloWorldService {
5开发人员应当知道的webservice知识
6开发人员应当知道的webservice知识 public String example(String message) {
7开发人员应当知道的webservice知识 return message;
8开发人员应当知道的webservice知识 }
9开发人员应当知道的webservice知识
10开发人员应当知道的webservice知识} 修改service.xml 文件,加入以下代码:
1开发人员应当知道的webservice知识<service>
2开发人员应当知道的webservice知识 <name>HelloWorldService</name>
3开发人员应当知道的webservice知识 <serviceClass>
4开发人员应当知道的webservice知识 com.myeclipse.wsExample.IHelloWorldService
5开发人员应当知道的webservice知识 </serviceClass>
6开发人员应当知道的webservice知识 <implementationClass>
7开发人员应当知道的webservice知识 com.myeclipse.wsExample.HelloWorldServiceImpl
8开发人员应当知道的webservice知识 </implementationClass>
9开发人员应当知道的webservice知识 <style>wrapped</style>
10开发人员应当知道的webservice知识 <use>literal</use>
11开发人员应当知道的webservice知识 <scope>application</scope>
12开发人员应当知道的webservice知识 </service> 把整个项目部署到tomcat服务器中 ,打开浏览器,输入http://localhost:8989/HelloWorld/services/HelloWorldService?wsdl,可以看到如下:
开发人员应当知道的webservice知识
然后再展开HelloWorldService后面的wsdl可以看到:
开发人员应当知道的webservice知识
客户端实现如下: 1开发人员应当知道的webservice知识package com.myeclipse.wsExample.client;
2开发人员应当知道的webservice知识
3开发人员应当知道的webservice知识import java.net.MalformedURLException;
4开发人员应当知道的webservice知识import java.net.URL;
5开发人员应当知道的webservice知识
6开发人员应当知道的webservice知识import org.codehaus.xfire.XFireFactory;
7开发人员应当知道的webservice知识import org.codehaus.xfire.client.Client;
8开发人员应当知道的webservice知识import org.codehaus.xfire.client.XFireProxyFactory;
9开发人员应当知道的webservice知识import org.codehaus.xfire.service.Service;
10开发人员应当知道的webservice知识import org.codehaus.xfire.service.binding.ObjectServiceFactory;
11开发人员应当知道的webservice知识
12开发人员应当知道的webservice知识import com.myeclipse.wsExample.IHelloWorldService;
13开发人员应当知道的webservice知识
14开发人员应当知道的webservice知识public class HelloWorldClient {
15开发人员应当知道的webservice知识public static void main(String[] args) throws MalformedURLException, Exception {
16开发人员应当知道的webservice知识// TODO Auto-generated method stub
17开发人员应当知道的webservice知识Service s=new ObjectServiceFactory().create(IHelloWorldService.class);
18开发人员应当知道的webservice知识XFireProxyFactory xf=new XFireProxyFactory(XFireFactory.newInstance().getXFire());
19开发人员应当知道的webservice知识String url="http://localhost:8989/HelloWorld/services/HelloWorldService";
20开发人员应当知道的webservice知识
21开发人员应当知道的webservice知识 try
22开发人员应当知道的webservice知识 {
23开发人员应当知道的webservice知识
24开发人员应当知道的webservice知识 IHelloWorldService hs=(IHelloWorldService) xf.create(s,url);
25开发人员应当知道的webservice知识 String st=hs.example("zhangjin");
26开发人员应当知道的webservice知识 System.out.print(st);
27开发人员应当知道的webservice知识 }
28开发人员应当知道的webservice知识 catch(Exception e)
29开发人员应当知道的webservice知识 {
30开发人员应当知道的webservice知识 e.printStackTrace();
31开发人员应当知道的webservice知识 }
32开发人员应当知道的webservice知识 }
33开发人员应当知道的webservice知识
34开发人员应当知道的webservice知识}
35开发人员应当知道的webservice知识 这里再说点题外话,有时候我们知道一个wsdl地址,比如想用java客户端引用.net 做得webservice,使用myeclipse引用,但是却出现无法通过验证的错误,这时我们可以直接在类中引用,步骤如下:
1开发人员应当知道的webservice知识public static void main(String[] args) throws MalformedURLException, Exception {
2开发人员应当知道的webservice知识 // TODO Auto-generated method stub
3开发人员应当知道的webservice知识 Service s=new ObjectServiceFactory().create(IHelloWorldService.class);
4开发人员应当知道的webservice知识 XFireProxyFactory xf=new XFireProxyFactory(XFireFactory.newInstance().getXFire());
5开发人员应当知道的webservice知识
6开发人员应当知道的webservice知识
7开发人员应当知道的webservice知识//远程调用.net开发的webservice
8开发人员应当知道的webservice知识Client c=new Client(new URL("http://www.webxml.com.cn/webservices/qqOnlineWebService.asmx?wsdl"));
9开发人员应当知道的webservice知识 Object[] o=c.invoke("qqCheckOnline", new String[]{"531086641","591284436"});
10开发人员应当知道的webservice知识
11开发人员应当知道的webservice知识//调用.net本机开发的webservice
12开发人员应当知道的webservice知识Client c1=new Client(new URL("http://localhost/zj/Service.asmx?wsdl"));
13开发人员应当知道的webservice知识Object[] o1=c1.invoke("HelloWorld",new String[]{});
14开发人员应当知道的webservice知识
15开发人员应当知道的webservice知识}
三、使用axis1.4调用webservice方法
前提条件:下载axis1.4包和tomcat服务器 ,并将axis文件夹复制到tomcat服务器的webapp文件夹中
这里我就说一下最简单的方法:
首先建立一个任意的java类(例如:HelloWorld.java),复制到axis文件夹下,将其扩展名改为jws,然后重新启动tomcat,在浏览器中输入http://localhost:8989/axis/HelloWorld.jws?wsdl,就会得到一个wsdl文件,其客户端调用方法如下:
1开发人员应当知道的webservice知识import javax.xml.rpc.Service;
2开发人员应当知道的webservice知识import javax.xml.rpc.ServiceException;
3开发人员应当知道的webservice知识import javax.xml.rpc.ServiceFactory;
4开发人员应当知道的webservice知识
5开发人员应当知道的webservice知识import java.net.MalformedURLException;
6开发人员应当知道的webservice知识import java.net.URL;
7开发人员应当知道的webservice知识import java.rmi.RemoteException;
8开发人员应当知道的webservice知识
9开发人员应当知道的webservice知识import javax.xml.namespace.QName;
10开发人员应当知道的webservice知识
11开发人员应当知道的webservice知识public class TestHelloWorld {
12开发人员应当知道的webservice知识
13开发人员应当知道的webservice知识
14开发人员应当知道的webservice知识 public static void main(String[] args) throws MalformedURLException, ServiceException, RemoteException {
15开发人员应当知道的webservice知识 // TODO Auto-generated method stub
16开发人员应当知道的webservice知识
17开发人员应当知道的webservice知识 String wsdlUrl ="http://localhost:8989/axis/HelloWorld.jws?wsdl";
18开发人员应当知道的webservice知识 String nameSpaceUri ="http://localhost:8989/axis/HelloWorld.jws";
19开发人员应当知道的webservice知识 String serviceName = "HelloWorldService";
20开发人员应当知道的webservice知识 String portName = "HelloWorld";
21开发人员应当知道的webservice知识
22开发人员应当知道的webservice知识 ServiceFactory serviceFactory = ServiceFactory.newInstance();
23开发人员应当知道的webservice知识 Service afService =serviceFactory.createService(new URL(wsdlUrl),new QName(nameSpaceUri, serviceName));
24开发人员应当知道的webservice知识 HelloWorldInterface proxy = (HelloWorldInterface)afService.getPort(new QName(nameSpaceUri, portName),HelloWorldInterface.class);
25开发人员应当知道的webservice知识 System.out.println("return value is "+proxy.getName("john") ) ;
26开发人员应当知道的webservice知识
27开发人员应当知道的webservice知识 }
28开发人员应当知道的webservice知识
29开发人员应当知道的webservice知识}
30开发人员应当知道的webservice知识四、使用axis2开发webservice(这里首先感谢李宁老师)
使用axis2 需要先下载

axis2-1.4.1-bin.zip

axis2-1.4.1-war.zip

http://ws.apache.org/axis2/
同理,也需要将axis2复制到webapp目录中
在axis2中部署webservice有两种方法,
第一种是pojo方式,这种方式比较简单,但是有一些限制,例如部署的类不能加上包名
第二种方式是利用xml发布webservice,这种方法比较灵活,不需要限制类的声明
下面分别说明使用方法:
1.pojo方式:在Axis2中不需要进行任何的配置,就可以直接将一个简单的POJO发布成WebService。其中POJO中所有的public方法将被发布成WebService方法。先实现一个pojo类:
1开发人员应当知道的webservice知识public class HelloWorld{
2开发人员应当知道的webservice知识 public String getName(String name)
3开发人员应当知道的webservice知识 {
4开发人员应当知道的webservice知识 return "你好 " + name;
5开发人员应当知道的webservice知识 }
6开发人员应当知道的webservice知识 public int add(int a,int b)
7开发人员应当知道的webservice知识 {
8开发人员应当知道的webservice知识 return a+b;
9开发人员应当知道的webservice知识 }
10开发人员应当知道的webservice知识}
11开发人员应当知道的webservice知识 由于这两个方法都是public类型,所以都会发布成webservice。编译HelloWorld类后,将HelloWorld.class文件放到%tomcat%\webapps\axis2\WEB-INF\pojo目录中(如果没有pojo目录,则建立该目录),然后打开浏览器进行测试:
输入一下url:

http://localhost:8080/axis2/services/listServices

会列出所有webservice
开发人员应当知道的webservice知识
这是其中的两个webservice列表,接着,在客户端进行测试:
首先可以写一个封装类,减少编码,代码如下:

1开发人员应当知道的webservice知识package MZ.GetWebService;
2开发人员应当知道的webservice知识import javax.xml.namespace.QName;
3开发人员应当知道的webservice知识
4开发人员应当知道的webservice知识import org.apache.axis2.AxisFault;
5开发人员应当知道的webservice知识import org.apache.axis2.addressing.EndpointReference;
6开发人员应当知道的webservice知识import org.apache.axis2.client.Options;
7开发人员应当知道的webservice知识import org.apache.axis2.rpc.client.RPCServiceClient;
8开发人员应当知道的webservice知识
9开发人员应当知道的webservice知识
10开发人员应当知道的webservice知识public class GetWSByAxis2 {
11开发人员应当知道的webservice知识 private static String EndPointUrl;
12开发人员应当知道的webservice知识 private static String QUrl="http://ws.apache.org/axis2";
13开发人员应当知道的webservice知识 private QName opAddEntry;
14开发人员应当知道的webservice知识 public String WSUrl;
15开发人员应当知道的webservice知识 public RPCServiceClient setOption() throws AxisFault
16开发人员应当知道的webservice知识 {
17开发人员应当知道的webservice知识 RPCServiceClient serviceClient = new RPCServiceClient();
18开发人员应当知道的webservice知识 Options options = serviceClient.getOptions();
19开发人员应当知道的webservice知识 EndpointReference targetEPR = new EndpointReference(WSUrl);
20开发人员应当知道的webservice知识 options.setTo(targetEPR);
21开发人员应当知道的webservice知识 return serviceClient;
22开发人员应当知道的webservice知识 }
23开发人员应当知道的webservice知识
24开发人员应当知道的webservice知识 public QName getQname(String Option){
25开发人员应当知道的webservice知识
26开发人员应当知道的webservice知识 return new QName (QUrl,Option);
27开发人员应当知道的webservice知识 }
28开发人员应当知道的webservice知识 //返回String
29开发人员应当知道的webservice知识 public String getStr(String Option) throws AxisFault
30开发人员应当知道的webservice知识 {
31开发人员应当知道的webservice知识 RPCServiceClient serviceClient =this.setOption();
32开发人员应当知道的webservice知识
33开发人员应当知道的webservice知识 opAddEntry =this.getQname(Option);
34开发人员应当知道的webservice知识
35开发人员应当知道的webservice知识 String str = (String) serviceClient.invokeBlocking(opAddEntry,
36开发人员应当知道的webservice知识 new Object[]{}, new Class[]{String.class })[0];
37开发人员应当知道的webservice知识 return str;
38开发人员应当知道的webservice知识 }
39开发人员应当知道的webservice知识// 返回一维String数组
40开发人员应当知道的webservice知识 public String[] getArray(String Option) throws AxisFault
41开发人员应当知道的webservice知识 {
42开发人员应当知道的webservice知识 RPCServiceClient serviceClient =this.setOption();
43开发人员应当知道的webservice知识
44开发人员应当知道的webservice知识 opAddEntry =this.getQname(Option);
45开发人员应当知道的webservice知识
46开发人员应当知道的webservice知识 String[] strArray = (String[]) serviceClient.invokeBlocking(opAddEntry,
47开发人员应当知道的webservice知识 new Object[]{}, new Class[]{String[].class })[0];
48开发人员应当知道的webservice知识 return strArray;
49开发人员应当知道的webservice知识 }
50开发人员应当知道的webservice知识 //从WebService中返回一个对象的实例
51开发人员应当知道的webservice知识 public Object getObject(String Option,Object o) throws AxisFault
52开发人员应当知道的webservice知识 {
53开发人员应当知道的webservice知识 RPCServiceClient serviceClient =this.setOption();
54开发人员应当知道的webservice知识 QName qname=this.getQname(Option);
55开发人员应当知道的webservice知识 Object object = serviceClient.invokeBlocking(qname, new Object[]{},new Class[]{o.getClass()})[0];
56开发人员应当知道的webservice知识 return object;
57开发人员应当知道的webservice知识 }
58开发人员应当知道的webservice知识
59开发人员应当知道的webservice知识///////////////////////////////////////// 读者可以自己封装数据类型,如int,byte,float等数据类型
60开发人员应当知道的webservice知识}
61开发人员应当知道的webservice知识客户端调用方法:
开发人员应当知道的webservice知识MZ.GetWebService.GetWSByAxis2 ws=new MZ.GetWebService.GetWSByAxis2();
开发人员应当知道的webservice知识ws.WSUrl="http://localhost:8989/axis2/services/HelloWorld";
开发人员应当知道的webservice知识HelloWorld hello= (HelloWorld)ws.getObject("getName", HelloWorld.class);
开发人员应当知道的webservice知识
开发人员应当知道的webservice知识
开发人员应当知道的webservice知识 System.out.println(hello.getName("zhangjin"));
开发人员应当知道的webservice知识 2.使用service.xml发布webservice,这种方式和直接放在pojo目录中的POJO类不同。要想将MyService类发布成Web Service,需要一个services.xml文件,这个文件需要放在META-INF目录中,该文件的内容如下:开发人员应当知道的webservice知识<service name="HelloWorld">
开发人员应当知道的webservice知识 <description>
开发人员应当知道的webservice知识 HelloWorld webservice
开发人员应当知道的webservice知识 </description>
开发人员应当知道的webservice知识 <parameter name="ServiceClass">
开发人员应当知道的webservice知识 service.HelloWorld
开发人员应当知道的webservice知识 </parameter>
开发人员应当知道的webservice知识 <messageReceivers>
开发人员应当知道的webservice知识 <messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-out"
开发人员应当知道的webservice知识 class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
开发人员应当知道的webservice知识 <messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-only"
开发人员应当知道的webservice知识 class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" />
开发人员应当知道的webservice知识 </messageReceivers>
开发人员应当知道的webservice知识</service>
开发人员应当知道的webservice知识
其中<service>元素用于发布Web Service,一个<service>元素只能发布一个WebService类,name属性表示WebService名,如下面的URL可以获得这个WebService的WSDL内容:
http://localhost:8080/axis2/services/myService?wsdl
除此之外,还有直接可以在其中制定webservice操作方法:可以这样些service.xml文件
1开发人员应当知道的webservice知识<service name="HelloWorld">
2开发人员应当知道的webservice知识 <description>
3开发人员应当知道的webservice知识 HelloWorld service
4开发人员应当知道的webservice知识 </description>
5开发人员应当知道的webservice知识 <parameter name="ServiceClass">
6开发人员应当知道的webservice知识 service.HelloWorld
7开发人员应当知道的webservice知识 </parameter>
8开发人员应当知道的webservice知识 <operation name="getName">
9开发人员应当知道的webservice知识 <messageReceiver class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
10开发人员应当知道的webservice知识 </operation>
11开发人员应当知道的webservice知识 <operation name="add">
12开发人员应当知道的webservice知识 <messageReceiver
13开发人员应当知道的webservice知识 class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" />
14开发人员应当知道的webservice知识 </operation>
15开发人员应当知道的webservice知识</service>
16开发人员应当知道的webservice知识如果要发布多个webservice,可以在文件两段加上<serviceGroup><service></service>...<service></service></serviceGroup>发布





以上纯属个人理解,如有疑义,欢迎大家拍砖啊!

读书人网 >Web前端

热点推荐