Webservice与eclipse

Web Service技术, 能使得运行在不同机器上的不同应用无须借助附加的、专门的第三方软件或硬件, 就可相互交换数据或集成。依据Web Service规范实施的应用之间, 无论它们所使用的语言、 平台或内部协议是什么, 都可以相互交换数据。Web Service是自描述、 自包含的可用网络模块, 可以执行具体的业务功能。Web Service也很容易部署, 因为它们基于一些常规的产业标准以及已有的一些技术,诸如标准通用标记语言下的子集XML、HTTP。Web Service减少了应用接口的花费。Web Service为整个企业甚至多个组织之间的业务流程的集成提供了一个通用机制。

webservice的描述性语言是基于xml格式展示的,所以wsdl既可以被机器阅读也可以被人阅读


Aixs2开发webService的方法有很多,在此只介绍一种比较简单的实现方法。

------------->第一步:首先要下载开发所需要的jar包



下载:axis2-1.6.1-war.zip

http://www.apache.org/dist//axis/axis2/java/core/1.6.1/

下载完后解压至tomcat安装目录下的webapps文件夹下,启动tomcat后,在webapps目录下会生成axis2文件夹。

访问http://localhost:8080/axis2/能看到以下页面表示axis2运行成功。

----------------->第二部

在Eclipse下新建Web Project,工程名:webServe。新建包com.cm.service,新建类HelloWorld,代码如下:

package com.cm.service;



public classHelloWorld {



    public String sayHello(String name){return "Hello, "+name+".";}

    public String saySorry(String name){return "Sorry,"+name+".";}

    public String getWorld(){return "Hello,World";}

   

}



在WEB-INF目录下修改web.xml文件,内容如下:

<?xmlversion="1.0"encoding="UTF-8"?>

<web-appversion="2.5">   

<!--Axis2 config start-->

<servlet>

    <servlet-name>AxisServlet</servlet-name>

    <servlet-class>org.apache.axis2.transport.http.AxisServlet</servlet-class>

    <load-on-startup>1</load-on-startup>

</servlet>

<servlet-mapping>

<servlet-name>AxisServlet</servlet-name> 

<url-pattern>/services/*</url-pattern> 

</servlet-mapping>



<!--Axis2  end-->

  <welcome-file-list>

    <welcome-file>index.jsp</welcome-file>

  </welcome-file-list>

</web-app>



把tomcat安装目录下的webapps/axis2/WEB-INF下的modules、service和conf文件件拷至HelloWorld下的WEB-INF目录下。把lib下的如下jar包也拷过去。


然后再services下新建HelloWorld/META-INF路径,META-INF下新建services.xml,内容如下:

<servicename="HelloWorld"> 

    <description> 

        HelloWorld Service Example

    </description> 

    <parameter name="ServiceClass"> 

        com.cm.service.HelloWorld

    </parameter> 
   
    <messageReceivers>
<messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-only" class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" />
<messageReceiver  mep="http://www.w3.org/2004/08/wsdl/in-out"  class="org.apache.axis2.rpc.receivers.RPCMessageReceiver"/>
    </messageReceivers>
    

</service> 

在访问前必须在struts.xml配置文件中进行过滤
<constant name="struts.action.excludePattern"value="/services/.*"/>
-----意思是告诉struts2在进行服务访问时不要将这个地址当成action对象来处理


启动tomcat后访问http://127.0.0.1:8888/上下文/services/HelloWorld?wsdl能看到服务信息了。

到此Axis2的WebService服务已成功发布


============================================================webservice生成客户端


Axis2客户端调用:

下面看看利用axis2 客户端调用实例



新建一个客户端调用类AxisUtil

代码如下:

package com.cm.client;





import javax.xml.namespace.QName;

import org.apache.axis2.addressing.EndpointReference;

import org.apache.axis2.client.Options;

import org.apache.axis2.rpc.client.RPCServiceClient;



public class AxisUtil {

    public static void main(String[] args) {

      

       String xmlStr="xiaoxu.wang";

        String url="http://127.0.0.1:8888/webServe/services/HelloWorld";
        //方法名
       String method="saySorry";

       AxisUtil.sendService(xmlStr,url,method);

    }

    public static String sendService(String xmlStr,String url,String method){

       String xml=null;

     

           RPCServiceClient serviceClient = new RPCServiceClient();

           Options options = serviceClient.getOptions();

           EndpointReference targetEPR = new EndpointReference(url);

           options.setTo(targetEPR);

           // 在创建QName对象时,QName类的构造方法的第一个参数表示WSDL文件的命名空间名,也就是<wsdl:definitions>元素的targetNamespace属性值
            ***********
            QName opAddEntry = new QName("http://service.cm.com",method);

            // 参数,如果有多个,继续往后面增加即可,不用指定参数的名称

            Object[] opAddEntryArgs = new Object[] {xmlStr};

                      // 返回参数类型,这个和axis1有点区别

            // invokeBlocking方法有三个参数,其中第一个参数的类型是QName对象,表示要调用的方法名;

            // 第二个参数表示要调用的WebService方法的参数值,参数类型为Object[];

            // 第三个参数表示WebService方法的返回值类型的Class对象,参数类型为Class[]。

            // 当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new Object[]{}

            // 如果被调用的WebService方法没有返回值,应使用RPCServiceClient类的invokeRobust方法,

            // 该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同

            Class[] classes = new Class[] { String.class };

            xml=(String)serviceClient.invokeBlocking(opAddEntry,opAddEntryArgs, classes)[0];

            System.out.println(xml);

        return xml;

    }

}



运行结果:

Sorry,xiaoxu.wang.[/color]

猜你喜欢

转载自liuzhiqiang19890403.iteye.com/blog/2013271