使用axis2进行webservice发布与调用

 一、介绍下cxf、axis、axis2区别

        新一代的Web Services 框架如Axis2、CXF 都是由现有的项目中逐渐演化而来的,Axis2 是由大家熟悉的Axis 1.x 系列演化过来,而Apache CXF 则是由Celtix和 XFire 项目整合而生,并且刚刚发布了2.0.2 的最新版本,不过仍是Apache 的一个孵化项目。
        Axis2 是对Axis 进行了彻底的重写的一个新项目了,它使用了新的模块化架构,更方便于功能性的扩展等等。
        Apache CXF 则是由XFire和 Celtix 两个现有的项目进行了重组。
问题:如果现有的应用程序是基于Axis 1.x、XFire或者 Celtix 的话,那应该怎么办?都迁移到这些新的框架上去吗?但是即使是要迁移,那应该迁移到哪个框架上去呢?
        如果是编写一个新的Web Services 应用程序的话,就不存在迁移的问题了,但是哪个框架是你应当选择进行使用的呢?哪个比哪个更好呢?
        对于现在的应用程序的迁移,如果你的应用程序是稳定成熟的,并且在可预知的未来的情况下,只要很少的一些需求变更要做的话,那么保存你的体力,不要去做“劳民伤财“的迁移工作了。
如果你的现有应用程序BUG缠身,性能,功能等等都一片糟糕的话,那就要考虑迁移了,那选哪个框架呢?先比较一下它们的不同之处:
    1、Apache CXF 支持WS-Addressing、WS-Policy、WS-RM、WS-Security和WS-I BasicProfile
    2、Axis2 支持WS-Addressing、WS-RM、WS-Security和WS-I BasicProfile,WS-Policy将在新版本里得到支持
    3、Apache CXF 是根据Spring哲学来进行编写的,即可以无缝地与Spring进行整合
    4、Axis2 不是
    5、Axis2 支持更多的data bindings,包括XMLBeans、JiBX、JaxMe和 JaxBRI,以及它原生的data binding(ADB)。
    6、Apache CXF 目前仅支持JAXB 和Aegis,并且默认是JAXB 2.0,与XFire默认是支持 Aegis不同,XMLBeans、JiBX和 Castor将在 CXF2.1 版本中得到支持,目前版本是 2.0.2
    7、Axis2 支持多种语言,它有C/C++ 版本。
    8、Apache CXF 提供方便的Spring整合方法,可以通过注解、Spring标签式配置来暴露Web Services和消费Web Services
如何抉择:
       1、如果应用程序需要多语言的支持,Axis2 应当是首选了;
       2、如果应用程序是遵循Spring 哲学路线的话,Apache CXF 是一种更好的选择,特别对嵌入式的Web Services 来说;
       3、如果应用程序没有新的特性需要的话,就仍是用原来项目所用的框架,比如Axis1,XFire,Celtrix或 BEA等等厂家自己的 WebServices 实现,就别劳民伤财了

二、eclipse插件下载 

2.1、打开下载地址

http://axis.apache.org/axis2/java/core/download.cgi

2.2 下载对应的版本

2.3、解压插件,解压后得到两个文件夹:axis2-eclipse-codegen-plugin-1.7.8和axis2-eclipse-service-plugin-1.7.8,拷贝至eclipse\plugins

 2.4、重新启动Eclipse,如在File->New->Other中有Axis2 Wizards,说明插件安装成功。

三、Axis2服务发布与调用

3.1、建一个webservice-provider的web工程,新增一个HelloService服务

public class HelloService {
    public String sayHello(){
        return "Hello World";
    }
    
    public String sayHelloToPerson(String name){
        if(name==null||name.equals("")){
            name="nobody";
        }
        return "Hello " + name;
    }
}

3.2 右击HelloService如图所示,生成具体的webservice服务

3.3 右击HelloService.java---Web Services---Create Web service.依次点击下一步……finish,此时发现WebContent目录下生成一个wsdl目录,目录下有一个HelloService.wsdl

3.4测试 web service :右击HelloService.wsdl---Web Services---Test with Web Services Explorer---点击方法名sayHelloToPerson----输入参数XXX---点go.此时会发现控制台输出Hello,XXX,说明 测试成功,WebService没有问题

 

注意如果不行的话,把wsdl删了,重新建一个。然后注意要在tomcat启动,否则服务发布不了

3.5 WebService服务调用,写一个测试类

import java.rmi.RemoteException;
import javax.xml.rpc.ParameterMode;
import javax.xml.rpc.ServiceException;
import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
import org.apache.axis.encoding.XMLType;

public class HelloServiceTest {
     public String invokeRemoteFuc() {
            // 远程调用路径
            String endpoint = "http://localhost:8855/webservice-provider/services/HelloService";
            //webservice的访问地址,这里是封装成了一个工具方法,根据文件名以及键来获取写在properties文件里的访问地址
        //    String endpoint = UtilProperties.getValueByKeyViaProp("myendpointAddress", "ws.properties");
            //预定义失败的默认返回值
            String result = "call failed!";
            //步骤1 构建 org.apache.axis.client.Service 对象
            Service service = new Service();
            Call call;
            try {
                // 步骤2:通过org.apache.axis.client.Service对象创建一个Call,需要强转为 org.apache.axis.client.Call类型
                call = (Call) service.createCall();
                // 步骤3:设置目标地址,即需要访问的webservice地址
                call.setTargetEndpointAddress(endpoint);
                // 步骤4:设置调用的方法名
                call.setOperationName("sayHelloToPerson");

                // 步骤5: 设置参数名
                call.addParameter("name", // 参数名
                        XMLType.XSD_STRING, // 参数类型:String
                        ParameterMode.IN); // 参数模式:'IN' or 'OUT'

                // 步骤6:设置返回值类型
                call.setReturnType(XMLType.XSD_STRING); // 返回值类型:String
                String name = "我是测试员";
                //步骤7 :调用call.invoke(Object[] obj)方法
                result = (String) call.invoke(new Object[] { name });// 远程调用
            } catch (ServiceException e) {
                e.printStackTrace();
            } catch (RemoteException e) {
                e.printStackTrace();
            }

            return result;
        }

        // 测试
        public static void main(String[] args) {
            HelloServiceTest test = new HelloServiceTest();
            String result = test.invokeRemoteFuc();
            System.out.println(result);
        }
}

3.6、讲项目跑起来,测试:HelloWorldTest ---Run as---Java application,如果发现控制台正确输出Hello 我是测试员,说明测试成功

 

posted @ 2018-09-17 10:58  shawWey  阅读(587)  评论(0编辑  收藏  举报