相关博客:
前言:
我们先来看一个契约优先的开发实例,通过熟悉他的开发流程,最后再和代码优先的方式进行比较。
Demo中提供了两个方法add()和minus().
1、编写wsdl文件
在新建的META-INF文件下新建名称为mywsdl的wsdl文件,因为之前已经详细介绍过wsdl的结构,在这里就直接上代码了。
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:tns="http://www.example.org/mywsdl/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
xmlns:xsd="http://www.w3.org/2001/XMLSchema" name="MyServiceImplService"
targetNamespace="http://www.example.org/mywsdl/">
<wsdl:types>
<xsd:schema targetNamespace="http://www.example.org/mywsdl/">
<!-- 1.1 编写元素add,addResponse,minus,minusResponse -->
<xsd:element name="add" type="tns:add"></xsd:element>
<xsd:element name="addResponse" type="tns:addResponse"></xsd:element> <xsd:element name="minus" type="tns:minus"></xsd:element>
<xsd:element name="minusResponse" type="tns:minusResponse"></xsd:element>
<!-- 1.2 编写元素的类型 -->
<xsd:complexType name="add">
<xsd:sequence>
<xsd:element name="a" type="xsd:int"></xsd:element>
<xsd:element name="b" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="addResponse">
<xsd:sequence>
<xsd:element name="addResult" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="minus">
<xsd:sequence>
<xsd:element name="c" type="xsd:int"></xsd:element>
<xsd:element name="d" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="minusResponse">
<xsd:sequence>
<xsd:element name="minusResult" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType>
</xsd:schema>
</wsdl:types>
<!-- 1.3 编写message -->
<wsdl:message name="add">
<wsdl:part name="add" element="tns:add"></wsdl:part>
</wsdl:message> <wsdl:message name="addResponse">
<wsdl:part name="addResponse" element="tns:addResponse"></wsdl:part>
</wsdl:message> <wsdl:message name="minus">
<wsdl:part name="minus" element="tns:minus"></wsdl:part>
</wsdl:message> <wsdl:message name="minusResponse">
<wsdl:part name="minusResponse" element="tns:minusResponse"></wsdl:part>
</wsdl:message> <!--1.4 编写port,其中operation为方法 -->
<wsdl:portType name="IMyService">
<wsdl:operation name="add">
<wsdl:input message="tns:add"></wsdl:input>
<wsdl:output message="tns:addResponse"></wsdl:output>
</wsdl:operation> <wsdl:operation name="minus">
<wsdl:input message="tns:minus"></wsdl:input>
<wsdl:output message="tns:minusResponse"></wsdl:output>
</wsdl:operation>
</wsdl:portType> <!--1.5 编写binding,其中document类型为默认 -->
<wsdl:binding name="myServiceSOAP" type="tns:IMyService">
<soap:binding style="document"
transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="add">
<!-- <soap:operation soapAction="http://www.example.org/mywsdl/NewOperation"/> -->
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation> <wsdl:operation name="minus">
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding> <!-- 1.6 编写service -->
<wsdl:service name="MyServiceImplService"><!-- 与公布接口的name一致 -->
<wsdl:port binding="tns:myServiceSOAP" name="MyServiceImplPort">
<soap:address location="http://localhost:8989/ms" /><!--
发布地址 -->
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
2、生成代码
同样,使用wsimport命令
在F:/WebService/03中找到生成的代码,copy到项目中。
注意:该阶段生成的代码是依据的是wsdl文件,例如:生成IMyService类中,有add()和minus()方法等。
3、发布服务
1)编写实现类
新建MyServiceImpl类,编写add(),minus()的具体实现。
需要注意的是,要制定wsdlLocation的地址,指明mywsdl的位置。
@WebService(endpointInterface="org.example.mywsdl.IMyService",
targetNamespace="http://www.example.org/mywsdl/",
wsdlLocation="META-INF/wsdl/mywsdl.wsdl")
public class MyServiceImpl implements IMyService { public int add(int a, int b) {
System.out.println(a+b);
return a+b;
} public int minus(int c, int d) {
System.out.println(c-d);
return c-d;
} }
2)发布服务
注意:http://localhost:8989/ms即wsdl文件中的服务地址。
public class MyServer { /**
* @param args
*/
public static void main(String[] args) {
Endpoint.publish("http://localhost:8989/ms", new MyServiceImpl()); } }
4、客户端测试
1)生成客户端代码
同样wsimport命令,只是最后不再是mywsdl.wsdl,而是我们服务的地址 http://localhost:8989/ms?wsdl。
2)测试
public static void main(String[] args) {
MyServiceImplService service=new MyServiceImplService();
IMyService ms=service.getMyServiceImplPort();
System.out.println(ms.add(3,5)); }
小结:
WebService中有两种实现方式:代码优先和契约优先。代码优先就是先编写程序代码,再自动生成wsdl文件。而后者正好相反,通过wsdl生成服务端和客户端,有种逆向工程的意思。
契约优先的方式虽然没有代码优先简单,但他有他的的优点。首先,契约优先与web服务的语言关联性不大,不受语言的限制。其次,如果先编写代码,如果服务编号,wsdl也要改变,然后重新发布接口服务,这样是十分不合理的。
因此,如果项目小,需求变动不大,可选择代码优先。反之,则推荐契约优先的方式。