webservice 的发布和调用,在网上找了一些资料总算是弄出来了,现将发布和调用做下简单总结。

第一步,准备工作。

1、  下载axis2 的2进制的包和war包:

axis2-1.4.1-war.zip:放到tomcate的文件

axis2-1.4.1-bin.zip:通过命令行生成测试代码

2、把下载后的war放入tomcat的webapps目录里,然后启动tomcat,这样war包就会自动解压为目录axis2,然后在浏览器中输入http://localhost:8080/axis2/,如果一切正常你会看到下面的画面:


 


       3、就开始准备一下axis2的eclispe的插件了。axis2的eclispe插件分为2个,一个是帮助我们生成aar文件的,另一个是帮我们用wsdl文件生成stub代码的。

      分别是:axis2-eclipse-service-archiver-wizard.zip、axis2-eclipse-codegen-wizard.zip。

下载完2个压缩文件后,可以直接把解压后的文件拷贝到plugins目录中,也可以在links目录中写文件路径的方式来安装插件,安装完插件后,打开eclipse,在package explorer 中点击右键--->选择new---->other….如果安装正确你会看到:


 

然后开始第二步,先来发布一个webservice:

package com.deltaj.server;
 
publicclass SimpleServer {
    /**
     *简单的测试方法
     */
    public String simpleMethod(String name) {
           return name + "Say this is a Simple method ^-^";
        }
}

主要的过程就是如何利用axis2的eclispe插件来发布这个服务啦。

1、  在eclispe 的package Explorer 中点击右键,在菜单中选择新建--->other...----->Axis2 Service Archiver


 

2、  然后点击next进入了类选择页面,在这个页面中的Class File Location选择框中选择类所在的文件夹。 (这里的class文件指的路劲是指项目编译之后再WEB-INF目录下的classes文件夹下的class文件,在这里目录指向classes目录就好了<在这里classes是class文件的根目录>,具体指定到哪个class文件在下面接着这个目录继续配置)。


 

3、点击next之后进入了选择 wsdl文件,这里我们选择skip wsdl。


 

4、点击next之后,进入的是选择jar文件的页面,这里我们没有外部的jar,所以点击next直接跳过这个页面。


 

 5、点击next之后,进入的是选择xml页面,这里我们选择的是自动生成xml,也就是勾选 Generate the service xml automatically这一项


 

6、点击next之后,进入的是生成xml文件的页面,在service name 里填写这个服务所起的名字,这里我起名为simpleServer,然后在class name 中填写要发布的类,这里一定要写全路径,写好后就可以点击load 按钮,如果一切ok的话,你会看到如下画面(这里是找需要发布的class文件,接着上面第2步的路径继续配置就能找到文件,要是出现Error :Classfoundcom.deltaj.server.SimpleServe 就是路劲配置错误)

    


 

7、点击next 后,进入的是输出artiver文件的页面,先要在output File location 中选择要输出的路径,在output  File Name中输入artiver文件的名称。我起的名字是simpleServer

      


 

8、点击finish ,如果看到如下的画面,说名发布成功啦。

   


 

9、接下来,我们就可以把这个aar文件放入tomcat中发布,首先把生成的aar文件拷贝到tomcat目录中的axis2项目的service目录中位置如图。

   


 

10、接下来启动tomcat,在地址栏中输入http://localhost:8080/axis2  ,你会看到axis2的欢迎画

11、点击Services连接,你会看到发布的服务列表。这里面就能看到我们发布的simpleService


 12、点击我们的服务simpleServer的连接,我们会看到。至此,服务发布成功。


 

我们看到自己的发布了一个webservice,那么下一步,自然是想测试下如何来调用它。

 

第三步,使用插件生成简化测试代码。(这里没有成功,改用密令行实现)

1、  在eclispe 的package Explorer 中点击右键,在菜单中选择新建--->other...----->Axis2 Code Generator


 

2、  点击next,进入下一个页面,选择从wsdl文件来产生java文件。


 

3、  点击next,然后选择wsdl文件,注意此处要填写上一节我们


 

4、.点击next,进入设置页面,这里我们就用默认的设置。


 

5、点击next,选择输出文件的路径。


 

6、点击next,如果看到这个页面,说名生成代码成功。


 

7、在package Explorer中刷新一下项目,然后你发现出现2个新的文件SimpleServerStub和SimpleServerCallbackHandler 。打开SimpleServerStub你会惊喜的发现。著名的小红叉一个接一个的这是因为没有axis2的类包。我们可以在下载的axis2-1.4.1-bin中找到lib包,把其中的jar都加入我们的工程中。

然后重新编译一下工程,这时我们发现SimpleServerStub还是有几个小红叉。这个是因为这个插件有个小bug。

生成的代码没有实现序列化方法。我们可以自己来加上,在小红叉上点一下,弹出一个小菜单,选择Add unimplemented methods .

/**
     *调用发布的服务。
     */
    publicclass SimpleClient {
       publicstaticvoid main(String[] args) throws Exception {
           // 初始化桩文件
           SimpleServerStub stub = new SimpleServerStub();
           // 初始化SimpleMethod方法。
           SimpleServerStub.SimpleMethod request = new SimpleServerStub.SimpleMethod();
           // 调用simpleMethod的setName方法。
           request.setName("zt");
           //      System.out.println(stub.simpleMethod(request).get_return());
       }
    }

 

如果一切正常,你就会看到结果

log4j:WARN No appenders could be found for logger (org.apache.axis2.description.AxisService).
log4j:WARN Please initialize the log4j system properly.
ztSay this is a Simple method ^-^。

可惜我没有那么幸运,通过这种向导的方式, 我遇到了不少人都遇到的一个异常,An error ocurred while completing process    -java.lang.reflect.InvocationTargetException。看到一些人的解决方案,我试着做了,依然不行。 关闭 Eclipse
- copy %AXIS2_HOME%\lib\backport-util-concurrent-3.1.jar 到下列 folder
%ECLIPSE_HOME%\plugins\Axis2_Codegen_Wizard_1.3.0\lib

注册此 jar 包: 編輯 %ECLIPSE_HOME%\plugins\Axis2_Codegen_Wizard_1.3.0\plugin.xml , 在 <runtime> 內加入下面的字串

<library name="lib/backport-util-concurrent-3.1.jar"> 
 <export name="*"/> 
 </library>



    执行 Eclipse 即可,若问题仍存在, 尝试改变Eclipse 使用的 JRE, 换成 JAVA 6

很无奈,总不能功亏一篑,再去问同事,他说他没有用插件向导的方式,用的是窗口方式,此时我才发现我缺少了一个包,就是上面提到的axis2的一个 包。里面有bin目录,于是下载后使用命令行,

G:\axis2-1.4.1\bin>wsdl2java -uri http://localhost:8080/axis2/services/simpleServer?wsdl -o D:\tt

如果出现:

Using AXIS2_HOME:   C:\soa\axis2
 Using JAVA_HOME:    E:\Program Files\Java\jdk1.6
 Retrieving document at 'http://219.237.203.117/cws/cws.asmx?WSDL'.

这三行后,在指定的目录中找到生成的两个java文件, 终于长舒一口气。剩下的就是写main函数测试,这个没有问题。按同样的方法去调用项目中的webservice,竟出现了错误,无奈,但至少这个 axis2的使用时没有问题的。

 

 

四、使用命令行生成简化调用服务的代码:

  1、补充插件的不足之处

复制 %AXIS2_HOME%\lib\backport-util-concurrent-3.1.jar 到
%ECLIPSE_HOME%\plugins\Axis2_Codegen_Wizard_1.3.0\lib

注册此 jar 包: 編輯 %ECLIPSE_HOME%\plugins\Axis2_Codegen_Wizard_1.3.0\plugin.xml , 在 <runtime> 內加入下面的字串

2、将axis2-1.4.1-bin.zip解压然后将解压文件放到一个可以找到的地方,在dos命令下执行:

<library name="lib/backport-util-concurrent-3.1.jar"> 
 <export name="*"/> 
 </library>

G:\axis2-1.4.1\bin>wsdl2java -uri http://localhost:8080/axis2/services/simpleServer?wsdl -o D:\tt

如果出现:
Using AXIS2_HOME:   C:\soa\axis2
Using JAVA_HOME:    E:\Program Files\Java\jdk1.6
Retrieving document at 'http://219.237.203.117/cws/cws.asmx?WSDL'.

说名生成成功,然后在指定的目录中找到生成的两个java文件,放到项目中去。

 

3、调用发布的service

/**
*调用发布的服务。
*/
    publicclass SimpleClient {
       publicstaticvoid main(String[] args) throws Exception {
           // 初始化桩文件
           SimpleServerStub stub = new SimpleServerStub();
           // 初始化SimpleMethod方法。
           SimpleServerStub.SimpleMethod request = new SimpleServerStub.SimpleMethod();
           // 调用simpleMethod的setName方法。
           request.setName("zt");
           //      System.out.println(stub.simpleMethod(request).get_return());
       }
    }

 

输出结果:

ztSay this is a Simple method ^-^.