首先是介绍整个流程
契约优先开发流程
1.先编写schema或者wsdl文件
2.根据这个文件生成一个客户端代码
3.编写实现类(在实现类上指定wsdlLocation)
4.发布服务
创建wsdl
1.在类路径META-INF下创建wsdl
2.新建wsdl并且编写文件
2.1编写type
2.2编写message
2.3编写portType指定接口和方法
2.4编写binding指定编码样式
2.5编写service(name要与命名空间名称一样)
3.根据名称生成服务器端代码
进入wsdl文件夹内用wsimport -d D:\sid\workspace_webservice\wsimport -keep mywsdl.wsdl
只留IMyService一个接口,其他的都删除
4.编写一个实现类实现接口
5.在实现类上指定wsdl的位置
指定targetNameSpace与接口的一样(可以不指定,但是需要自己重新添加方法的返回标注等)
@WebService(endpointInterface="org.example.mywsdl.IMyService",
targetNamespace="http://www.example.org/mywsdl/",
wsdlLocation="META-INF/wsdl/mywsdl.wsdl")
6.启动服务
然后在启动时候可以热修改,直接修改wsdl文件
7.执行服务器wsimport,生成客户端代码
wsimport -d D:\sid\workspace_webservice\wsimport -keep -verbose http://localhost:8989/ms?wsdl
8.加入header
wsdl文件中修改:
<!-- 定义头部信息 -->
<xsd:element name="licenseInfo" type="xsd:string"/>
<!-- 定义头信息 -->
<wsdl:message name="licenseInfo">
<wsdl:part name="licenseInfo" element="tns:licenseInfo"/>
</wsdl:message>
<!-- 在方法中加入头信息 -->
<soap:header use="literal" part="licenseInfo" message="tns:licenseInfo"/>
修改IMyService的add方法
public int add(
@WebParam(name = "a", targetNamespace = "")
int a,
@WebParam(name = "b", targetNamespace = "")
int b,
@WebParam(name = "licenseInfo", header=true)
String licenseInfo);
代码如下:
mywsdl.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="mywsdl" targetNamespace="http://www.example.org/mywsdl/">
<wsdl:types>
<xsd:schema targetNamespace="http://www.example.org/mywsdl/">
<!-- 定义方法 -->
<xsd:element name="add" type="tns:add"/>
<xsd:element name="addResponse" type="tns:addResponse"/>
<xsd:element name="divide" type="tns:divide"/>
<xsd:element name="divideResponse" type="tns:divideResponse"/>
<!-- 定义头部信息 -->
<xsd:element name="licenseInfo" type="xsd:string"/>
<!-- 定义类型 -->
<xsd:complexType name="add">
<xsd:sequence>
<xsd:element name="a" type="xsd:int"/>
<xsd:element name="b" type="xsd:int"/>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name="addResponse">
<xsd:sequence>
<xsd:element name="addResult" type="xsd:int"/>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name="divide">
<xsd:sequence>
<xsd:element name="num1" type="xsd:int"/>
<xsd:element name="num2" type="xsd:int"/>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name="divideResponse">
<xsd:sequence>
<xsd:element name="divideResult" type="xsd:int"/>
</xsd:sequence>
</xsd:complexType>
</xsd:schema>
</wsdl:types>
<wsdl:message name="add">
<wsdl:part name="add" element="tns:add"/>
</wsdl:message>
<wsdl:message name="addResponse">
<wsdl:part name="addResponse" element="tns:addResponse"/>
</wsdl:message>
<wsdl:message name="divide">
<wsdl:part name="divide" element="tns:divide"/>
</wsdl:message>
<wsdl:message name="divideResponse">
<wsdl:part name="divideResponse" element="tns:divideResponse"/>
</wsdl:message>
<!-- 定义头信息 -->
<wsdl:message name="licenseInfo">
<wsdl:part name="licenseInfo" element="tns:licenseInfo"/>
</wsdl:message>
<wsdl:portType name="IMyService">
<wsdl:operation name="add">
<wsdl:input message="tns:add"/>
<wsdl:output message="tns:addResponse"/>
</wsdl:operation>
<wsdl:operation name="divide">
<wsdl:input message="tns:divide"/>
<wsdl:output message="tns:divideResponse"/>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="myServiceSOAP" type="tns:IMyService">
<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name="add">
<wsdl:input>
<soap:body use="literal"/>
<!-- 加入头信息 -->
<soap:header use="literal" part="licenseInfo" message="tns:licenseInfo"/>
</wsdl:input>
<wsdl:output>
<soap:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="divide">
<wsdl:input>
<soap:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap:body use="literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="MyServiceImplService">
<wsdl:port binding="tns:myServiceSOAP" name="MyServiceImplPort">
<soap:address location="http://localhost:8989/ms"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
只留IMyservice类,并进行修改:
package org.example.mywsdl;
import javax.jws.WebMethod;
import javax.jws.WebParam;
import javax.jws.WebResult;
import javax.jws.WebService;
import javax.xml.bind.annotation.XmlSeeAlso;
import javax.xml.ws.RequestWrapper;
import javax.xml.ws.ResponseWrapper;
/**
* This class was generated by the JAX-WS RI.
* JAX-WS RI 2.2.4-b01
* Generated source version: 2.2
*
*/
@WebService(name = "IMyService",
targetNamespace = "http://www.example.org/mywsdl/")
public interface IMyService {
/**
*
* @param b
* @param a
* @return
* returns int
*/
@WebMethod
@WebResult(name = "addResult", targetNamespace = "")
@RequestWrapper(localName = "add", targetNamespace = "http://www.example.org/mywsdl/", className = "org.example.mywsdl.Add")
@ResponseWrapper(localName = "addResponse", targetNamespace = "http://www.example.org/mywsdl/", className = "org.example.mywsdl.AddResponse")
public int add(
@WebParam(name = "a", targetNamespace = "")
int a,
@WebParam(name = "b", targetNamespace = "")
int b,
@WebParam(name = "licenseInfo", header=true)
String licenseInfo);
/**
*
* @param num2
* @param num1
* @return
* returns int
*/
@WebMethod
@WebResult(name = "divideResult", targetNamespace = "")
@RequestWrapper(localName = "divide", targetNamespace = "http://www.example.org/mywsdl/", className = "org.example.mywsdl.Divide")
@ResponseWrapper(localName = "divideResponse", targetNamespace = "http://www.example.org/mywsdl/", className = "org.example.mywsdl.DivideResponse")
public int divide(
@WebParam(name = "num1", targetNamespace = "")
int num1,
@WebParam(name = "num2", targetNamespace = "")
int num2);
}
创建实现类之后发布服务
package org.example.mywsdl;
import javax.xml.ws.Endpoint;
public class MyServer {
public static void main(String[] args) {
//地址是在wsdl中编写的
Endpoint.publish("http://localhost:8989/ms", new MyServiceImpl());
}
}
根据服务器端生成客户端代码后:
wsimport -d D:\sid\workspace_webservice\wsimport -keep -verbose http://localhost:8989/ms?wsdl
加入测试类:
package org.example.test;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import javax.xml.namespace.QName;
import javax.xml.soap.MessageFactory;
import javax.xml.soap.SOAPBody;
import javax.xml.soap.SOAPBodyElement;
import javax.xml.soap.SOAPEnvelope;
import javax.xml.soap.SOAPException;
import javax.xml.soap.SOAPHeader;
import javax.xml.soap.SOAPMessage;
import javax.xml.ws.Dispatch;
import javax.xml.ws.Service;
public class Test {
public static void main(String[] args) {
String ns = "http://www.example.org/mywsdl/";
try {
QName name = new QName(ns,"MyServiceImplService");
URL url = new URL("http://localhost:8989/ms?wsdl");
// MyServiceImplService mis = new MyServiceImplService(url,name);
// IMyService ms = mis.getMyServiceImplPort();
// System.out.println(ms.divide(19, 2));
//使用soap来传递消息
Service service = Service.create(url,name);
QName pname = new QName(ns,"MyServiceImplPort");
Dispatch<SOAPMessage> dispatch = service.createDispatch(pname, SOAPMessage.class, Service.Mode.MESSAGE);
SOAPMessage msg = MessageFactory.newInstance().createMessage();
SOAPEnvelope enve = msg.getSOAPPart().getEnvelope();
SOAPHeader header = enve.getHeader();
SOAPBody body = enve.getBody();
if (header==null) {
header = enve.addHeader();
}
QName hname = new QName(ns,"licenseInfo","ns");
header.addHeaderElement(hname).setValue("sssssssss");
QName bname = new QName(ns,"add","ns");
SOAPBodyElement ele = body.addBodyElement(bname);
ele.addChildElement("a").setValue("12");
ele.addChildElement("b").setValue("12");
msg.writeTo(System.out);
System.out.println("\n invoking。。。。。。。。");
SOAPMessage rep = dispatch.invoke(msg);
rep.writeTo(System.out);
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (SOAPException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
分享到:
相关推荐
WebService的WSDL文件生成Java代码工具
详细介绍3种方法根据wsdl逆向生成webservice服务端;有最原始的wsdl2java指令,还有通过soapUI工具以及通过myeclipse的web service project来生成。
webService通过axis编辑wsdl文件生成代码
根据WSDL文件生成客户端代码与创建客户端工程 注意小细节:在根据对方提供的webservice地址,先将对方webservice的wsdl文件描述文件保存到本地时,格式先保存为xml,后将其后缀名为.wsdl的文件 否则报:...
Eclipse根据wsdl文件逆向生成webservice客户端项目源码,包括wsdl文件,测试示例,测试webservice代码,包含备注信息
通过此方法可以把webservice接口通过接口生成的wsdl文件生成本地调用代码,详细配置可以查看wsdl2_java登入.bat文件,此包原来放在H盘根目录,双击wsdl2_java登入.bat文件即可以生成Create文件夹中的JAVA代码
根据对方提供的webservice地址,你先将对方webservice的wsdl文件描述文件保存到本地为后缀名为.wsdl的文件,然后保存到Tools的这个文件夹下,编辑WSDL2AxisClient.bat这个文件,将%Java_Cmd% org.apache.axis.wsdl....
C#调用WebService实例和开发(wsdl).rar
C#调用WebService实例和开发,对于初学者来说,在vs2012环境中,大家有可能不知道Web References文件夹是如何来的,它是通过右击项目,选择其中的”添加服务引用“。
Eclipse根据wsdl文件自动生成webservice client图解,以及调用示例,附测试项目。源码示例,包括两个wsdl文件
NULL 博文链接:https://wjch-111.iteye.com/blog/2375406
使用cxf wsdl2java生成webservice客户端命令
使用WSDL生成webService接口,编写Test调用方法进行测试
利用axis jar包 根据wsdl文件生成java webservice 工具 (附带生成后调用方法和详细说明) 及其适合工作着与初学者调试和学习,已经通过测试完全可用
axis2根据wsdl生成java客户端代码 D:\Software\axis2-1.6.2\bin>wsdl2java.bat -uri http://10.33.30.216:9099/facs/services/ResourceSynchroWebService?wsdl -o E:\wsdloutput -p com.util wsdl2java.bat -uri ...
利用注解修改webservice生成wsdl的服务名称,命名空间,返回值,调用方法。加强安全性。代码完整,包括服务端和客户端两个项目
通过wsdl文件就可以通过客户端调用服务端的接口,可以使用Webservice的服务了
利用wsdl.exe生成webservice代理类: 根据提供的wsdl生成webservice代理类 1、开始->程序->Visual Studio 2005 命令提示 2、输入如下红色标记部分 D:\Program Files\Microsoft Visual Studio 8\VC>wsdl /...
webService接口用eclipse工具WSDL生成服务端和客户端(http协议,xml构造传输),本人研究了好几天已成功,希望大家参考帖子少走弯路