如何根据WSDL文档开发部署Web Service服务?

WSDL文档是描述Web Service接口该如何开发和部署的具体描述文档,十分重要。一个接口的WSDL文档里会包含接口部署时的服务名(service name),接口的绑定信息,绑定端口信息和接口方法中的参数信息等。根据这些信息,我们可以通过WSDL文档反向自动建立接口的java代码结构,提高开发工作效率。

下面介绍一下使用WSDL文档反向自动建立接口的java代码结构的步骤。

一、新建Dynamic Web Project 项目。

二、在项目中添加已有的WSDL文档。

WSDL文档直接放在项目根目录下。

WSDL文档内容说明:

三、根据该WSDL反向生成接口java代码结构。

1、在项目上右键,进入新建web service配置窗口。

2、选择Web ServiceNext

3、配置web service

包括创建web service用哪种类型、选择一个wsdl文档、配置tomcatweb service运行环境以及service所在项目、webservice处于哪个进度(选develop阶段)。

其中service implementations选择我们在步骤(三.1)中导入的wsdl文件。

Web service type选项栏中有两个可选项,分别是 Bottom up Java bean Web ServiceTop down Java bean Web Service。前者表示根据已有的JAVA文件生成WSDL文档和web service服务,后者表示根据已有的WSDL文档反向生成web service服务的JAVA代码结构。

在这里,我们选择后者。

4、接下来就都是next,最后finishweb service代码结构已经生成了。

接下来的工作,就是在IfAPServiceSoapBindingImpl.java文件中编写我们的业务逻辑代码,可以另外创建其他package包,合理安排代码模块。

四、web service的业务代码编写完之后,开始发布。

1、新建发布文件server-config.wsdd

自动发布的方法,就是在项目的WEB-INF路径下新建一个server-config.wsdd发布文件。这个文件的大部分内容可以来源于模板(模板内容稍后贴出),只有<service>...</service>部分填写刚写好的web service的发布部署信息。这部分信息在自动生成的deploy.wsdd中已经有了,我们可以直接拿过来,复制到server-config.wsdd中。

注:server-config.wsdd的基本内容如下:

<?xml version="1.0"encoding="UTF-8"?>

<deployment xmlns="http://xml.apache.org/axis/wsdd/"

    xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">

    <globalConfiguration>

       <parameter name="adminPassword" value=XXXX" />

       <parameter name="p_w_uploads.Directory" value="D:\Tomcat\temp\axis\WEB-INF\p_w_uploads"/>

       <parameter name="p_w_uploads.implementation"

           value="org.apache.axis.p_w_uploads.AttachmentsImpl"/>

       <parameter name="sendXsiTypes" value="true" />

       <parameter name="sendMultiRefs" value="true" />

       <parameter name="sendXMLDeclaration" value="true" />

       <parameter name="axis.sendMinimizedElements" value="true" />

       <requestFlow>

           <handler type="java:org.apache.axis.handlers.JWSHandler">

              <parameter name="scope" value="session"/>

           </handler>

           <handler type="java:org.apache.axis.handlers.JWSHandler">

              <parameter name="scope" value="request"/>

              <parameter name="extension" value=".jwr"/>

           </handler>

       </requestFlow>

    </globalConfiguration>

    <handler name="LocalResponder"

       type="java:org.apache.axis.transport.local.LocalResponder"/>

    <handler name="URLMapper" type="java:org.apache.axis.handlers.http.URLMapper"/>

    <handler name="Authenticate"

       type="java:org.apache.axis.handlers.SimpleAuthenticationHandler"/>

    <service name="AdminService" provider="java:MSG">

       <parameter name="allowedMethods" value="AdminService" />

       <parameter name="enableRemoteAdmin" value="false" />

       <parameter name="className" value="org.apache.axis.utils.Admin"/>

       <namespace>http://xml.apache.org/axis/wsdd/</namespace>

    </service>

<!--   <service name="Version"provider="java:RPC"> -->

<!--       <parameter name="allowedMethods"value="getVersion" /> -->

<!--       <parameter name="className"value="org.apache.axis.Version" /> -->

<!--   </service> -->

    <!--myself webservice-->

 <service name="IfAPService" provider="java:RPC" style="rpc"use="encoded">

     <parameter name="wsdlTargetNamespace" value="http://eaaapi.eaa.eidc.huawei.com/"/>

     <parameter name="wsdlServiceElement" value="IfAPService"/>

     <parameter name="wsdlServicePort" value="IfAPService"/>

     <parameter name="className" value="com.huawei.eidc.eaa.eaaapi.IfAPServiceSoapBindingSkeleton"/>

     <parameter name="wsdlPortType" value="APService"/>

     <parameter name="typeMappingVersion" value="1.2"/>

     <parameter name="allowedMethods" value="*"/>

 </service>

    <transport name="http">

       <requestFlow>

           <handler type="URLMapper" />

           <handler type="java:org.apache.axis.handlers.http.HTTPAuthHandler"/>

       </requestFlow>

       <parameter name="qs:list"

           value="org.apache.axis.transport.http.QSListHandler"/>

       <parameter name="qs.list"

           value="org.apache.axis.transport.http.QSListHandler"/>

       <parameter name="qs:method"

           value="org.apache.axis.transport.http.QSMethodHandler"/>

       <parameter name="qs.method"

           value="org.apache.axis.transport.http.QSMethodHandler"/>

       <parameter name="qs:wsdl"

           value="org.apache.axis.transport.http.QSWSDLHandler"/>

       <parameter name="qs.wsdl"

           value="org.apache.axis.transport.http.QSWSDLHandler"/>

    </transport>

    <transport name="local">

       <responseFlow>

           <handler type="LocalResponder" />

       </responseFlow>

    </transport>

</deployment>

2、发布web service

在上述步骤之后,我们可以发布接口项目了。只需要将项目打包成war文件,并将war包放到指定的tomcatwebapps路径下,启动tomcat。这里我们把打包的包名设为webTest.war

3、查看发布的web service是否成功。

在浏览器中输入: http://localhost:8080/webTest/services

注意不要在”services”后面加斜杠/ ’),得到下面的结果,可知web service发布成功。

五、测试代码

import java.io.IOException;

import javax.xml.namespace.QName;
import model.Utility;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.rpc.client.RPCServiceClient;
import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpException;
import org.apache.commons.httpclient.NameValuePair;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.http.params.CoreConnectionPNames;

 

/**模拟ADCSI发送数据请求*/

public class ADC2SI {

private static String test_url = "http://172.0.0.1:8080/webTest/services/IfAPService";

//调用SI接口,发送post请求
public static void main(String[] args) throws HttpException, IOException{
String str = "params";
postmethod2(test_url,str);
}
public static void postmethod2(String url, String str) throws HttpException, IOException{
// 使用RPC方式调用WebService
RPCServiceClient serviceClient = new RPCServiceClient();
Options options = serviceClient.getOptions();
// 指定调用WebServiceURL
EndpointReference targetEPR = new EndpointReference(url);
options.setTo(targetEPR);
// 指定要调用的sayHelloToPerson方法及WSDL文件的命名空间
QName opAddEntry = new QName("http://eaaapi.eaa.eidc.huawei.com","corpBinding");
// 指定sayHelloToPerson方法的参数值
Object[] opAddEntryArgs = new Object[] { str };
// 指定sayHelloToPerson方法返回值的数据类型的Class对象
@SuppressWarnings("
rawtypes")
Class[] classes = new Class[] { String.class };
// 调用sayHelloToPerson方法并输出该方法的返回值
try{
System.out.println(serviceClient.invokeBlocking(opAddEntry,opAddEntryArgs, classes)[0]);
System.
out.println("发送数据 SUCCESS");
}catch(Exception e){
System.
out.println("发送数据 FAILED");
}
}