zoukankan      html  css  js  c++  java
  • WebService的学习

    一.WebService到底是什么??
    一言以蔽之:WebService是一种跨编程语言和跨操作系统平台的远程调用技术。
     所谓跨编程语言和跨操作平台,就是说服务端程序采用java编写,客户端程序则可以采用其他编程语言编写,反之亦然!跨操作系统平台则是指服务端程序和客户端程序可以在不同的操作系统上运行。
    所谓远程调用,就是一台计算机a上的一个程序可以 调用到另外一台计算机b上的一个对象的方法,譬如,银联提供给商场的pos刷卡系统,商场的POS机转账调用的转账方法的代码其实是跑在银行服务器上。再 比如,amazon,天气预报系统,淘宝网,校内网,百度等把自己的系统服务以webservice服务的形式暴露出来,让第三方网站和程序可以调用这些 服务功能,这样扩展了自己系统的市场占有率,往大的概念上吹,就是所谓的SOA应用。

    其实可以从多个角度来理解 WebService,从表面上看,WebService就是一个应用程序向外界暴露出一个能通过Web进行调用的API,也就是说能用编程的方法通过 Web来调用这个应用程序。我们把调用这个WebService的应用程序叫做客户端,而把提供这个WebService的应用程序叫做服务端。从深层次 看,WebService是建立可互操作的分布式应用程序的新平台,是一个平台,是一套标准。它定义了应用程序如何在Web上实现互操作性,你可以用任何 你喜欢的语言,在任何你喜欢的平台上写Web service ,只要我们可以通过Web service标准对这些服务进行查询和访问。 

       WebService平台需要一套协议来实现分布式应用程序的创建。任何平台都有它的数据表示方法和类型系统。要实现互操作性,WebService平台 必须提供一套标准的类型系统,用于沟通不同平台、编程语言和组件模型中的不同类型系统。Web service平台必须提供一种标准来描述 Web service,让客户可以得到足够的信息来调用这个Web service。最后,我们还必须有一种方法来对这个Web service进行远 程调用,这种方法实际是一种远程过程调用协议(RPC)。为了达到互操作性,这种RPC协议还必须与平台和编程语言无关。
     
    二.WebService平台技术
    XML+XSD,SOAP和WSDL就是构成WebService平台的三大技术。
     

    XML+XSD:

      WebService采用HTTP协议传输数据,采用XML格式封装数据(即XML中说明调用远程服务对象的哪个方法,传递的参数是什么,以及服务对象的 返回结果是什么)。XML是WebService平台中表示数据的格式。除了易于建立和易于分析外,XML主要的优点在于它既是平台无关的,又是厂商无关 的。无关性是比技术优越性更重要的:软件厂商是不会选择一个由竞争对手所发明的技术的。 

      XML解决了数据表示的问题,但它没有定义一套标准的数据类型,更没有说怎么去扩展这套数据类型。例如,整形数到底代表什么?16位,32位,64位?这 些细节对实现互操作性很重要。XML Schema(XSD)就是专门解决这个问题的一套标准。它定义了一套标准的数据类型,并给出了一种语言来扩展这套数据类型。WebService平台就 是用XSD来作为其数据类型系统的。当你用某种语言(如VB.NET或C#)来构造一个Web service时,为了符合WebService标准,所 有你使用的数据类型都必须被转换为XSD类型。你用的工具可能已经自动帮你完成了这个转换,但你很可能会根据你的需要修改一下转换过程。
     

    SOAP:

       WebService通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明 HTTP消息的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议。SOAP提供了标准的RPC方法来调用Web Service。

      SOAP协议 = HTTP协议 + XML数据格式

      SOAP协议定义了SOAP消息的格式,SOAP协议是基于HTTP协议的,SOAP也是基于XML和XSD的,XML是SOAP的数据编码方式。打个比 喻:HTTP就是普通公路,XML就是中间的绿色隔离带和两边的防护栏,SOAP就是普通公路经过加隔离带和防护栏改造过的高速公路。

    WSDL:

       好比我们去商店买东西,首先要知道商店里有什么东西可买,然后再来购买,商家的做法就是张贴广告海报。 WebService也一样,WebService客户端要调用一个WebService服务,首先要有知道这个服务的地址在哪,以及这个服务里有什么方 法可以调用,所以,WebService务器端首先要通过一个WSDL文件来说明自己家里有啥服务可以对外调用,服务是什么(服务中有哪些方法,方法接受 的参数是什么,返回值是什么),服务的网络地址用哪个url地址表示,服务通过什么方式来调用。

       WSDL(Web Services Description Language)就是这样一个基于XML的语言,用于描述Web Service及其函数、参数和返回值。它是WebService客户端和服务器端都 能理解的标准格式。因为是基于XML的,所以WSDL既是机器可阅读的,又是人可阅读的,这将是一个很大的好处。一些最新的开发工具既能根据你的 Web service生成WSDL文档,又能导入WSDL文档,生成调用相应WebService的代理类代码。

      WSDL 文件保存在Web服务器上,通过一个url地址就可以访问到它。客户端要调用一个WebService服务之前,要知道该服务的WSDL文件的地址。 WebService服务提供商可以通过两种方式来暴露它的WSDL文件地址:1.注册到UDDI服务器,以便被人查找;2.直接告诉给客户端调用者。
     
    三.WebService开发

    WebService开发可以分为服务器端开发和客户端开发两个方面:

       服 务端开发:把公司内部系统的业务方法发布成WebService服务,供远程合作单位和个人调用。(借助一些WebService框   架可以很轻松地把自己的业务对象发布成WebService服务,Java方面的典型WebService框架包括:axis,xfire,cxf 等,java ee服务器通常也支持发布WebService服务,例如JBoss。)
       客户端开发:调用别人发布的WebService服务,大多数人从事的开发都属于这个方面,例如,调用天气预报WebService服务。(使用厂 商的WSDL2Java之类的工具生成静态调用的代理类代码;使用厂商提供的客户端编程API类;使用SUN公司早期标准的jax-rpc开发包;使用 SUN公司最新标准的jax-ws开发包。当然SUN已被ORACLE收购)

       WebService 的工作调用原理:对客户端而言,我们给这各类WebService客户端API传递wsdl文件的url地址,这些API就会创建出底层的代理类,我调用 这些代理,就可以访问到webservice服务。代理类把客户端的方法调用变成soap格式的请求数据再通过HTTP协议发出去,并把接收到的soap 数据变成返回值返回。对服务端而言,各类WebService框架的本质就是一个大大的Servlet,当远程调用客户端给它通过http协议发送过来 soap格式的请求数据时,它分析这个数据,就知道要调用哪个java类的哪个方法,于是去查找或创建这个对象,并调用其方法,再把方法返回的结果包装成 soap格式的数据,通过http响应消息回给客户端。
     
    四.常用的WebService框架:CXF  和 Axis
       
        如果你需要多语言的支持,你应该选择AXIS2。如果你需要把你的实现侧重JAVA并希望和Spring集成,CXF就是更好的选择,特别是把你的Web Service嵌入其他的程序中。
     
    五.Webservice的使用(以CXF为例,因为它能与Spring很好地结合)
       
         在web.xml中配置如下:
     <?xml version= "1.0" encoding ="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
          xmlns:context="http://www.springframework.org/schema/context"
          xmlns:jaxws="http://cxf.apache.org/jaxws" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://www.springframework.org/schema/beans  
         http://www.springframework.org/schema/beans/spring-beans-3.0.xsd    
         http://www.springframework.org/schema/context    
         http://www.springframework.org/schema/context/spring-context-3.0.xsd     http://cxf.apache.org/jaxws      http://cxf.apache.org/schemas/jaxws.xsd">
         <import resource="classpath:META-INF/cxf/cxf.xml" />
         <import resource="classpath:META-INF/cxf/cxf-extension-soap.xml" />
         <import resource="classpath:META-INF/cxf/cxf-servlet.xml" />
              //一般是三种标签:< jaxws:server>< jaxws:client><jaxws:endpoint>
         <!--作为webservice的服务器端,发布服务-->
          <bean id="rcServiceBean" class="com.cdp.rc.webservices.RcServiceImp" ></bean>
         
         <jaxws:server id="rcService"
               serviceClass="com.cdp.rc.webservices.IRcService" address="/rcService" >
               <jaxws:serviceBean>
                   <ref bean= "rcServiceBean" />
               </jaxws:serviceBean>
         </jaxws:server >
         <!--作为webservice的客户端,调用Address后的所在路径的服务,serviceClass为本项目中使用此webservice服务的接口-->
          <jaxws:client id="bpmClient" 
                 serviceClass="com.cdp.bpm.webservices.IBpmService"  address="http://192.168.9.234:8080/bpm/webservices/bpmService" >
        </jaxws:client >
         <!--和jaxws:server一样,也是作为webservice的服务器端,发布服务,不过两者还是有区别的-->
           <bean id="PaXmlExportService" class="com.cdp.hra.pa.webservice.PaExportWebserviceProvider" ></bean>
         <jaxws:endpoint id="paExport" implementor="#PaXmlExportService" address="/paXmlExport">
               <jaxws:inInterceptors>
                   <bean class="org.apache.cxf.interceptor.LoggingInInterceptor" />
                   <bean class="org.apache.cxf.binding.soap.saaj.SAAJInInterceptor" />
                   <ref bean= "wss4jInConfigurationQoros" />
               </jaxws:inInterceptors>
               <jaxws:outInterceptors>
                   <bean class="org.apache.cxf.interceptor.LoggingOutInterceptor" />
                   <bean class="org.apache.cxf.binding.soap.saaj.SAAJOutInterceptor" />
                   <ref bean= "wss4jOutConfigurationQoros" />
               </jaxws:outInterceptors>
         </jaxws:endpoint >
    </ beans>

    java类的编写:

     @WebService(targetNamespace = "webservice.rc.cdp.com" )
    public interface IRcService {
         @WebResult(name = "response")
         public String changeOfferApproveStatus(@WebParam (name = "sysSip" ) String sysSip,
                   @WebParam(name="clientcode" )String clientcode,
                   @WebParam(name = "bizId" ) String bizId,
                   @WebParam(name = "status" ) String status,
                   @WebParam(name = "remark" ) String remark);
    }
        它的实现类:
    @Service
    public class RcServiceImp implements IRcService {
         
         @Override
         @WebResult(name = "response")
         public String changeOfferApproveStatus(@WebParam (name = "sysSip" ) String sysSip,
                   @WebParam(name="clientcode" )String clientcode,
                   @WebParam(name = "bizId" ) String bizId,
                   @WebParam(name = "status" ) String status,
                   @WebParam(name = "remark" ) String remark) {
              //内容
                 System.out.println( "haha");
          }
    targetNamespace :提供服务的一方提供的WSDL的命名空间,客户端使用的时候需要它:
    然后就是服务的客户端,即调用这个接口:
    @WebService(targetNamespace = "webservice.rc.cdp.com" )
    public interface IRcService {
         @WebResult(name = "response")
         public String changeOfferApproveStatus(@WebParam (name = "sysSip" ) String sysSip,
                   @WebParam(name="clientcode" )String clientcode,
                   @WebParam(name = "bizId" ) String bizId,
                   @WebParam(name = "status" ) String status);
    }
    客户端也定义一个和服务器端一样的接口,然后可以在客户端的项目中随便调用该接口
  • 相关阅读:
    java后台设计简单的json数据接口,设置可跨域访问,前端ajax获取json数据
    java 多线程研究:锁的概念
    PHP 学习笔记之一:thinkPHP的volist标签
    Flask 学习篇二:学习Flask过程中的记录
    Docker 学习应用篇之三: Docker的简单实用
    CodeForces 832B Petya and Exam
    CodeForce 832A Sasha and Sticks
    Docker 学习应用篇之二: Docker的介绍和安装
    ASP.NET中AJAX的异步加载(Demo演示)
    Java实现 蓝桥杯VIP 算法训练 连通分块(并查集)
  • 原文地址:https://www.cnblogs.com/shilin000/p/4759348.html
Copyright © 2011-2022 走看看