(二)发布第一个WebService服务与DSWL文档解析
1. 编写接口
package service; import javax.jws.WebService; /** * 第一个webservice服务, * @WebService注解表示这是一个webservice服务 * @author Administrator * */ @WebService public interface WebService_1 { public int add(int x,int y); }
2. 编写实现类
package serviceImpl; import javax.jws.WebService; import javax.swing.plaf.synth.SynthSeparatorUI; import service.WebService_1; /** * web服务的实现类,endpointInterface指的是对外提供服务的接口 * @author Administrator * */ @WebService(endpointInterface = "service.WebService_1") public class WebService_1_impl implements WebService_1 { @Override public int add(int x, int y) { System.out.println("返回两数相加结果"); return x + y; } }
3. 发布
package test; import javax.xml.ws.Endpoint; import serviceImpl.WebService_1_impl; public class Test { public static void main(String[] args) {
//publish方法第一个参数是发布后访问的请求地址,第二个参数是服务的实现 Endpoint.publish("http://localhost:3031/first", new WebService_1_impl()); System.out.println("发布成功......"); } }
4. 结果并解析
5. wsdl文档解析
WSDL(Web Services Description Language,Web服务描述语言)是为描述Web Services发布的XML格式。W3C组织没有批准1.1版的WSDL,但是2.0版本已经在製訂中,2.0版将被作为推荐标准(recommendation)(一种官方标准),并将被W3C组织批准为正式标准。WSDL描述Web服务的公共接口。这是一个基于XML的关于如何与Web服务通讯和使用的服务描述;也就是描述与目录中列出的Web服务进行交互时需要绑定的协议和信息格式。通常采用抽象语言描述该服务支持的操作和信息,使用的时候再将实际的网络协议和信息格式绑定给该服务。
WSDL 文档仅仅是一个简单的 XML 文档。它包含一系列描述某个 web service 的定义。
WebMthod的定义:
1: [WebService(Namespace = "http://tempuri.org/")] 2: [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] 3: [System.ComponentModel.ToolboxItem(false)] 4: public class WebService2 : System.Web.Services.WebService 5: { 6: [WebMethod] 7: public bool Add(TestClass testClass,int id) 8: { 9: return true; 10: } 11: } 12: 13: public class TestClass 14: { 15: public int a; 16: public string b; 17: public DateTime c; 18: } 19:
WSDL的结构:
一个WSDL文档通常包含有以下元素,即types、message、portType、operation、binding、 service元素。这些元素嵌套在definitions元素中。
definitions是WSDL文档的根元素,definitions还声明各命名空间。
types,数据类型定义的容器,它使用某种类型系统(一般地使用XML Schema中的类型系统)。
1: <wsdl:types> 2: <s:schema elementFormDefault="qualified" targetNamespace="http://tempuri.org/"> 3: <s:element name="Add"> 4: <s:complexType> 5: <s:sequence> 6: <s:element minOccurs="0" maxOccurs="1" name="testClass" type="tns:TestClass" /> 7: <s:element minOccurs="1" maxOccurs="1" name="id" type="s:int" /> 8: </s:sequence> 9: </s:complexType> 10: </s:element> 11: <s:complexType name="TestClass"> 12: <s:sequence> 13: <s:element minOccurs="1" maxOccurs="1" name="a" type="s:int" /> 14: <s:element minOccurs="0" maxOccurs="1" name="b" type="s:string" /> 15: <s:element minOccurs="1" maxOccurs="1" name="c" type="s:dateTime" /> 16: </s:sequence> 17: </s:complexType> 18: <s:element name="AddResponse"> 19: <s:complexType> 20: <s:sequence> 21: <s:element minOccurs="1" maxOccurs="1" name="AddResult" type="s:boolean" /> 22: </s:sequence> 23: </s:complexType> 24: </s:element> 25: </s:schema> 26: </wsdl:types>
types描述WebMethod的名称(Add),传入参数(testClass——包括对TestClass的详细描述,id),响应信息(AddResponse)。
message描述通信消息的数据结构的抽象类型化定义,使用types的描述的类型来定义整个消息的数据结构。
1: <wsdl:message name="AddSoapIn"> 2: <wsdl:part name="parameters" element="tns:Add" /> 3: </wsdl:message> 4: <wsdl:message name="AddSoapOut"> 5: <wsdl:part name="parameters" element="tns:AddResponse" /> 6: </wsdl:message>
portType和operation描述服务和服务的方法。operation包括输入和输出(使用message的描述)。
1: <wsdl:portType name="WebService2Soap"> 2: <wsdl:operation name="Add"> 3: <wsdl:input message="tns:AddSoapIn" /> 4: <wsdl:output message="tns:AddSoapOut" /> 5: </wsdl:operation> 6: </wsdl:portType>
binding描述Web Services的通信协议。 <soap:binding/>描述使用SOAP协议,binding还描述Web Services的方法、输入、输出。
1: <wsdl:binding name="WebService2Soap" type="tns:WebService2Soap"> 2: <soap:binding transport="http://schemas.xmlsoap.org/soap/http" /> 3: <wsdl:operation name="Add"> 4: <soap:operation soapAction="http://tempuri.org/Add" style="document" /> 5: <wsdl:input> 6: <soap:body use="literal" /> 7: </wsdl:input> 8: <wsdl:output> 9: <soap:body use="literal" /> 10: </wsdl:output> 11: </wsdl:operation> 12: </wsdl:binding>
service描述Web Services访问点的集合。因为包括SOAP1.1和SOAP1.2的描述,所以一个方法有对应两描述。
<wsdl:service name="WebService2"><wsdl:port name="WebService2Soap" binding="tns:WebService2Soap"><soap:address location="http://localhost:1552/WebService2.asmx" /></wsdl:port><wsdl:port name="WebService2Soap12" binding="tns:WebService2Soap12"><soap12:address location="http://localhost:1552/WebService2.asmx" /></wsdl:port></wsdl:service>