一、简介

  对于基于soap传输协议的webservice有两种开发模式,代码优先和契约优先的模式。代码优先的模式是通过编写服务器端的代码,使用代码生成wsdl;契约优先模式首先编写wsdl,再通过wsdl生成服务器端的代码。对于代码优先的模式在使用cxf构建webservice 一文中已经做出介绍,这里主要介绍第二种方式。

二、wsdl文件结束

  一般wsdl文件结构如下:

<?xml version='1.0' encoding='UTF-8'?>
<wsdl:definitions xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:tns="http://testauto.cxf.com/"
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:ns1="http://schemas.xmlsoap.org/soap/http"
name="MyServiceImplService" targetNamespace="http://testauto.cxf.com/"> <!-- 元素和元素类型 -->
<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://testauto.cxf.com/" elementFormDefault="unqualified"
targetNamespace="http://testauto.cxf.com/" version="1.0"> <xs:element name="sayHello" type="tns:sayHello" />
<xs:element name="sayHelloResponse" type="tns:sayHelloResponse" /> <xs:complexType name="sayHello">
<xs:sequence>
<xs:element minOccurs="0" name="arg0" type="xs:string" />
<xs:element minOccurs="0" name="arg1" type="xs:string" />
<xs:element minOccurs="0" name="arg2" type="xs:string" />
</xs:sequence>
</xs:complexType> <xs:complexType name="sayHelloResponse">
<xs:sequence>
<xs:element minOccurs="0" name="return" type="xs:string" />
</xs:sequence>
</xs:complexType> </xs:schema>
</wsdl:types> <!-- message -->
<wsdl:message name="sayHelloResponse">
<wsdl:part element="tns:sayHelloResponse" name="parameters">
</wsdl:part>
</wsdl:message>
<wsdl:message name="sayHello">
<wsdl:part element="tns:sayHello" name="parameters">
</wsdl:part>
</wsdl:message> <!-- operation -->
<wsdl:portType name="MyService">
<wsdl:operation name="sayHello">
<wsdl:input message="tns:sayHello" name="sayHello">
</wsdl:input>
<wsdl:output message="tns:sayHelloResponse" name="sayHelloResponse">
</wsdl:output>
</wsdl:operation>
</wsdl:portType> <!-- binding -->
<wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService">
<soap:binding style="document"
transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="sayHello">
<soap:operation soapAction="" style="document" />
<wsdl:input name="sayHello">
<soap:body use="literal" />
</wsdl:input>
<wsdl:output name="sayHelloResponse">
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding> <wsdl:service name="MyServiceImplService">
<wsdl:port binding="tns:MyServiceImplServiceSoapBinding"
name="MyServiceImplPort">
<soap:address location="http://localhost:9000/myservice" />
</wsdl:port>
</wsdl:service>
</wsdl:definitions>

  对于根元素中的xmlns与targetNamespace是包名的反转,name为实现类的名称。其他的属性都是固定的。

  <wsdl:types> 中主要定义元素和元素的类型。 一般对于一个接口来说,参数的整体作为一个输入元素类型,接口的返回值也是作为一个输出的元素类型。

  <wsdl:message > 主要定义接口的请求和响应消息。<wsdl:part>中的element属性使用到了<wsdl:types> 中定义的元素。

  <wsdl:portType name="MyService"> 主要定义了接口的操作,name表示接口的名称;<wsdl:operation name="sayHello">定义了具体的方法,name为方法的名称。子元素input和output使用到了message元素。

   <wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService"> type为wsdl:portType中的那么值;name为我们自己定义的。子元素<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http" />是固定的。 <wsdl:operation name="sayHello">中子元素input和outputname和operation中子元素的name一直。

  <wsdl:service name="MyServiceImplService">定义了绑定的信息,<wsdl:port binding="tns:MyServiceImplServiceSoapBinding">type就是绑定的时候定义的name,子元素address为定义的地址;增加接口的时候不需要更改。

  wsdl是一个基于schema的xml文件,通过这个文件我们可以定义出接口的名称,参数类型,返回值等信息,也可以同该文件生成客户端和服务器端代码。

三、wsdl的各种返回类型

  1、返回列表类型

       对应于 List<Student> getStudentsByAge(int age) 方法,wsdl相关定义如下:

<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://testauto.cxf.com/" elementFormDefault="unqualified" targetNamespace="http://testauto.cxf.com/" version="1.0">
<xsd:element name="getStudentsByAgeRequest" type="tns:AgetType"></xsd:element>
<xsd:element name="getStudentsByAgeResponse" type="tns:StudentsType"></xsd:element>
</xs:schema>
</wsdl:types> <xsd:complexType name="AgetType">
<xsd:sequence>
<xsd:element name="age" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="StudentsType">
<xsd:sequence>
<xsd:element name="students" minOccurs="0" maxOccurs="unbounded" type="tns:StudentType"></xsd:element> <!-- 元素出现的次数为0-无限多次 -->
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="StudentType">
<xsd:sequence>
<xsd:element name="id" type="xsd:int"></xsd:element>
<xsd:element name="name" type="xsd:string"></xsd:element>
</xsd:sequence>
</xsd:complexType> <!-- message -->
<wsdl:message name="getStudentsByAgeRequest">
<wsdl:part name="parameters" element="tns:getStudentsByAgeRequest"></wsdl:part>
</wsdl:message>
<wsdl:message name="getStudentsByAgeResponse" >
<wsdl:part name="parameters" element="tns:getStudentsByAgeResponse"></wsdl:part>
</wsdl:message> <!-- operation -->
<wsdl:portType name="MyService">
<wsdl:operation name="getStudentsByAge">
<wsdl:input message="tns:getStudentsByAgeRequest" name="getStudentsByAgeRequest"></wsdl:input>
<wsdl:output message="tns:getStudentsByAgeResponse" name="getStudentsByAgeResponse"></wsdl:output>
</wsdl:operation>
</wsdl:portType> <!-- binding info -->
<wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService">
<wsdl:operation name="getStudentsByAge">
<soap:operation soapAction="" style="document"/>
<wsdl:input name="getStudentsByAgeRequest">
<soap:body use="literal"/>
</wsdl:input>
<wsdl:output name="getStudentsByAgeResponse">
<soap:body use="literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>

  在MyServiceImplPortImpl中的实现方法,可以做如下类似实现

public com.cxf.test.StudentsType getStudentsByAge(AgetType parameters) {
LOG.info("Executing operation getStudentsByAge");
System.out.println(parameters);
try {
System.out.println("getStudentsByAge invoked!");
System.out.println("gae : " + parameters.getAge());
com.cxf.test.StudentsType students = new StudentsType();
StudentType stu1 = new StudentType();
stu1.setName("zhangsan1"); StudentType stu2 = new StudentType();
stu1.setName("zhangsan2"); students.getStudents().add(stu1);
students.getStudents().add(stu2); return students;
} catch (java.lang.Exception ex) {
ex.printStackTrace();
throw new RuntimeException(ex);
}
}

  2、voide 无返回值类型

   对应于 void deleteById(int id) 方法,wsdl相关定义如下:

<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://testauto.cxf.com/" elementFormDefault="unqualified"
targetNamespace="http://testauto.cxf.com/" version="1.0"> <xsd:element name="deleteByIdRequest" type="tns:IdType"></xsd:element>
<xsd:element name="deleteByIdResponse">
<xsd:complexType>
<xsd:sequence></xsd:sequence>
</xsd:complexType>
</xsd:element>
<xsd:complexType name="IdType">
<xsd:sequence>
<xsd:element name="id" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType> </xs:schema>
</wsdl:types> <!-- message -->
<wsdl:message name="deleteByIdRequest">
<wsdl:part name="parameters" element="tns:deleteByIdRequest"></wsdl:part>
</wsdl:message>
<wsdl:message name="deleteByIdResponse">
<wsdl:part name="parameters" element="tns:deleteByIdResponse"></wsdl:part>
</wsdl:message> <!-- operation -->
<wsdl:portType name="MyService">
<wsdl:operation name="deleteById">
<wsdl:input message="tns:deleteByIdRequest" name="deleteByIdRequest"></wsdl:input>
<wsdl:output message="tns:deleteByIdResponse" name="deleteByIdResponse"></wsdl:output>
</wsdl:operation>
</wsdl:portType> <!-- binding info -->
<wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService">
<wsdl:operation name="deleteById">
<soap:operation soapAction="" style="document" />
<wsdl:input name="deleteByIdRequest">
<soap:body use="literal" />
</wsdl:input>
<wsdl:output name="deleteByIdResponse">
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>

  此时我们可以将生成的deleteById方法的返回类型改成void,需要同时修改接口和实现类。如:
  MyService 接口中的方法

 @SOAPBinding(parameterStyle = SOAPBinding.ParameterStyle.BARE)
@WebResult(name = "deleteByIdResponse", targetNamespace = "http://test.cxf.com/", partName = "parameters")
@WebMethod
public void deleteById(
@WebParam(partName = "parameters", name = "deleteByIdRequest", targetNamespace = "http://test.cxf.com/")
IdType parameters
);

  MyServiceImplPortImpl类中的方法

 public void deleteById(IdType parameters) {
LOG.info("Executing operation deleteById");
System.out.println(parameters);
try { System.out.println(parameters.getId());
} catch (java.lang.Exception ex) {
ex.printStackTrace();
throw new RuntimeException(ex);
}
}

  3、返回枚举类型

  枚举为:enum{TEACHER, STUDENT, PRESIDENT} ;对应的方法为:enum getRoleById(int id),wsdl定义如下:

<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://testauto.cxf.com/" elementFormDefault="unqualified"
targetNamespace="http://testauto.cxf.com/" version="1.0"> <xsd:element name="getRoleByIdRequest" type="tns:IdType"></xsd:element>
<xsd:element name="getRoleByIdResponse" type="tns:RoleType"></xsd:element>
<xsd:complexType name="IdType">
<xsd:sequence>
<xsd:element name="id" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType>
<xsd:simpleType name="RoleType">
<xsd:restriction base="xs:string">
<xsd:enumeration value="STUDENT"></xsd:enumeration>
<xsd:enumeration value="TEACHER"></xsd:enumeration>
<xsd:enumeration value="PRESIDENT"></xsd:enumeration>
</xsd:restriction>
</xsd:simpleType> </xs:schema>
</wsdl:types> <!-- message -->
<wsdl:message name="getRoleByIdRequest">
<wsdl:part name="parameters" element="tns:getRoleByIdRequest"></wsdl:part>
</wsdl:message>
<wsdl:message name="getRoleByIdResponse">
<wsdl:part name="paramters" element="tns:getRoleByIdResponse"></wsdl:part>
</wsdl:message> <!-- operation -->
<wsdl:portType name="MyService">
<wsdl:operation name="getRoleById">
<wsdl:input message="tns:getRoleByIdRequest" name="getRoleByIdRequest"></wsdl:input>
<wsdl:output message="tns:getRoleByIdResponse" name="getRoleByIdResponse"></wsdl:output>
</wsdl:operation>
</wsdl:portType> <!-- binding info -->
<wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService">
<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="getRoleById">
<soap:operation soapAction="" style="document" />
<wsdl:input name="getRoleByIdRequest">
<soap:body use="literal" />
</wsdl:input>
<wsdl:output name="getRoleByIdResponse">
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>

  在MyServiceImplPortImpl中的实现方法,可以做如下类似实现

 public com.cxf.test.RoleType getRoleById(IdType parameters) {
LOG.info("Executing operation getRoleById");
System.out.println(parameters);
try {
System.out.println("id: " + parameters.getId());
com.cxf.test.RoleType roleType = RoleType.PRESIDENT;
return roleType;
} catch (java.lang.Exception ex) {
ex.printStackTrace();
throw new RuntimeException(ex);
}
}

  4、返回嵌套的对象类型

  嵌套对象结构如下

Student{
  int id;
  String name;
  Date date;
  Teacher teacher;
}
Teacher{
  String name;
  Boss boss;
}

Boss{
  String name;
  Parent parent;
}

Parent{
  String name;
}

  对于的方法为:Student getStudentById(int studentId),wsdl文件如下:

<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://testauto.cxf.com/" elementFormDefault="unqualified"
targetNamespace="http://testauto.cxf.com/" version="1.0"> <xsd:element name="getStudentByIdRequest" type="tns:StudentIdType"></xsd:element>
<xsd:element name="getStudentByIdResponse" type="tns:StudentType"></xsd:element> <xsd:complexType name="StudentIdType">
<xsd:sequence>
<xsd:element name="id" type="xsd:int"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="StudentType">
<xsd:sequence>
<xsd:element name="id" type="xsd:int"></xsd:element>
<xsd:element name="name" type="xsd:string"></xsd:element>
<xsd:element name="date" type="xsd:date"></xsd:element>
<xsd:element name="teacher" type="tns:TeacherType"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="TeacherType">
<xsd:sequence>
<xsd:element name="name" type="xsd:string"></xsd:element>
<xsd:element name="boss" type="tns:BossType"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="BossType">
<xsd:sequence>
<xsd:element name="name" type="xsd:string"></xsd:element>
<xsd:element name="parent" type="tns:ParentType"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="ParentType">
<xsd:sequence>
<xsd:element name="name" type="xsd:string"></xsd:element>
</xsd:sequence>
</xsd:complexType> </xs:schema>
</wsdl:types> <!-- message -->
<wsdl:message name="getStudentByIdRequest">
<wsdl:part name="parameters" element="tns:getStudentByIdRequest"></wsdl:part>
</wsdl:message>
<wsdl:message name="getStudentByIdResponse">
<wsdl:part name="parameters" element="tns:getStudentByIdResponse"></wsdl:part>
</wsdl:message> <!-- operation -->
<wsdl:portType name="MyService">
<wsdl:operation name="getStudentById">
<wsdl:input message="tns:getStudentByIdRequest" name="getStudentByIdRequest"></wsdl:input>
<wsdl:output message="tns:getStudentByIdResponse" name="getStudentByIdResponse"></wsdl:output>
</wsdl:operation>
</wsdl:portType> <!-- binding info -->
<wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService">
<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="getStudentById">
<soap:operation soapAction="" style="document" />
<wsdl:input name="getStudentByIdRequest">
<soap:body use="literal" />
</wsdl:input>
<wsdl:output name="getStudentByIdResponse">
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>

  在MyServiceImplPortImpl中的实现方法,可以做如下类似实现

public com.cxf.test.StudentType getStudentById(StudentIdType parameters) {
LOG.info("Executing operation getStudentById");
System.out.println(parameters);
try {
ParentType parentType = new ParentType();
parentType.setName("lisi"); BossType bossType = new BossType();
bossType.setName("boss");
bossType.setParent(parentType); TeacherType teacherType = new TeacherType();
teacherType.setName("teacher");
teacherType.setBoss(bossType); com.cxf.test.StudentType student = new StudentType();
student.setId(parameters.getId());
student.setName("zhangsan");
student.setDate(getGregorianCalendar(new Date()));
student.setTeacher(teacherType); return student;
} catch (java.lang.Exception ex) {
ex.printStackTrace();
throw new RuntimeException(ex);
}
} private XMLGregorianCalendar getGregorianCalendar(Date date){
GregorianCalendar gc = new GregorianCalendar();
gc.setTime(date);
XMLGregorianCalendar calendar = new com.sun.org.apache.xerces.internal.jaxp.datatype.XMLGregorianCalendarImpl(gc);
return calendar;
}

  客户端调用的时候

 com.cxf.test.StudentIdType id = new StudentIdType();
id.setId(11111);
com.cxf.test.StudentType student = port.getStudentById(id);
System.out.println(student.getId());
System.out.println(student.getName());
System.out.println(student.getDate());
System.out.println(student.getTeacher().getBoss().getParent().getName());

  5、文件上传

  boolean upload(File file ),wsdl文件如下:

<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://test.cxf.com/" elementFormDefault="unqualified"
targetNamespace="http://test.cxf.com/" version="1.0">
<xsd:element name="uploadRequest" type="tns:FileType"></xsd:element>
<xsd:element name="uploadResponse" type="tns:booleanType"></xsd:element>
<xsd:complexType name="booleanType">
<xsd:sequence>
<xsd:element name="result" type="xsd:boolean"></xsd:element>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name="FileType">
<xsd:sequence>
<xsd:element name="fileContent" type="xsd:base64Binary"></xsd:element> <!-- 文件类型 -->
</xsd:sequence>
</xsd:complexType> </xs:schema>
</wsdl:types> <!-- message -->
<wsdl:message name="uploadRequest">
<wsdl:part name="parameters" element="tns:uploadRequest"></wsdl:part>
</wsdl:message>
<wsdl:message name="uploadResponse">
<wsdl:part name="parameters" element="tns:uploadResponse"></wsdl:part>
</wsdl:message> <!-- operation -->
<wsdl:portType name="MyService">
<wsdl:operation name="upload">
<wsdl:input message="tns:uploadRequest" name="uploadRequest"></wsdl:input>
<wsdl:output message="tns:uploadResponse" name="uploadResponse"></wsdl:output>
</wsdl:operation>
</wsdl:portType> <!-- binding info -->
<wsdl:binding name="MyServiceImplServiceSoapBinding" type="tns:MyService">
<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="upload">
<soap:operation soapAction="" style="document" />
<wsdl:input name="uploadRequest">
<soap:body use="literal" />
</wsdl:input>
<wsdl:output name="uploadResponse">
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>

  接口实现类如下:

 public com.cxf.test.BooleanType upload(FileType parameters) {
LOG.info("Executing operation upload");
System.out.println(parameters);
try {
byte[] buffer = parameters.getFileContent();
OutputStream os = new FileOutputStream(new File("test2.txt"));
os.write(buffer);
os.close(); com.cxf.test.BooleanType result = new BooleanType();
result.setFilename(true);
return result;
} catch (java.lang.Exception ex) {
ex.printStackTrace();
throw new RuntimeException(ex);
}
}

  客户端调用如下:

 System.out.println("Invoking upload...");
com.cxf.test.FileType data = new FileType();
InputStream is = new FileInputStream(new File("c:/apache-cxf-3.0.3.zip"));
byte[] buffer = new byte[is.available()];
is.read(buffer);
data.setFileContent(buffer);
com.cxf.test.BooleanType result = port.upload(data);
System.out.println(result.isResult());

  这种上传方式有些缺陷,当文件达到一定大小的时候,就会报java.lang.OutOfMemoryError: Java heap space异常。因为这种方式是一次性读取文件,将文件发送给服务器的。

6、使用MTOM文件上传

  这种方法可以解决普通上传遇到的问题。使用MTO上传需要在wsdl定义元素部分添加 xmlns:xmime="http://www.w3.org/2005/05/xmlmime"

命名空间,element添加属性xmime:expectedContentTypes="application/octet-stream"其他部分与普通上传一样。如下所示:

<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://test.cxf.com/" elementFormDefault="unqualified"
xmlns:xmime="http://www.w3.org/2005/05/xmlmime" targetNamespace="http://test.cxf.com/"
version="1.0"> <!-- 添加xmlns:xmime 元素 --> <xsd:element name="uploadRequest" type="tns:FileType"></xsd:element>
<xsd:element name="uploadResponse" type="tns:booleanType"></xsd:element>
<xsd:complexType name="booleanType">
<xsd:sequence>
<xsd:element name="result" type="xsd:boolean"></xsd:element>
</xsd:sequence>
</xsd:complexType> <xsd:complexType name="FileType">
<xsd:sequence>
<!-- 添加xmime:expectedContentTypes="application/octet- -->
<xsd:element name="fileContent" type="xsd:base64Binary"
xmime:expectedContentTypes="application/octet-stream"></xsd:element>
</xsd:sequence>
</xsd:complexType> </xs:schema>
</wsdl:types>

  使用MTOM需要服务端和客户端都需要开启MTOM

  服务端开启MTOM代码如下:

 protected MyService_MyServiceImplPort_Server() throws java.lang.Exception {
System.out.println("Starting Server");
Object implementor = new MyServiceImplPortImpl();
String address = "http://localhost:9000/myservice";
javax.xml.ws.Endpoint endPoint = javax.xml.ws.Endpoint.publish(address, implementor); //服务器端开启MTOM
javax.xml.ws.soap.SOAPBinding binding = (javax.xml.ws.soap.SOAPBinding)endPoint.getBinding();
binding.setMTOMEnabled(true);
}

  接口的实现

public com.cxf.test.BooleanType upload(FileType parameters) {
LOG.info("Executing operation upload");
System.out.println(parameters);
try { javax.activation.DataHandler dataHandler = parameters.getFileContent(); //获取文件输入流
InputStream is = dataHandler.getInputStream(); //获取输出流
OutputStream os = new FileOutputStream(new File("c:/apache-cxf-3.0.3.zip.back")); //进行文件保存
int length = 0;
byte[] buffer = new byte[1024];
while(-1 != (length = is.read(buffer))){
os.write(buffer, 0, length);
} os.close();
is.close(); com.cxf.test.BooleanType result = new BooleanType();
result.setResult(true);
return result;
} catch (java.lang.Exception ex) {
ex.printStackTrace();
throw new RuntimeException(ex);
}
}

  客户端的调用

MyService port = ss.getMyServiceImplPort();

// 客户端开启MTOM
javax.xml.ws.Binding binding = ((javax.xml.ws.BindingProvider)
port).getBinding();
((javax.xml.ws.soap.SOAPBinding)
binding).setMTOMEnabled(true);
System.out.println("Invoking upload..."); //构造数据
DataSource ds = new FileDataSource(new File("c:/apache-cxf-3.0.3.zip")); com.cxf.test.FileType data = new FileType();
data.setFileContent(new DataHandler(ds)); //调用接口
com.cxf.test.BooleanType result = port.upload(data);
System.out.println(result.isResult());

四、使用wsdl生成代码

  将的bin目录添加到系统环境变量path中,如(C:\apache-cxf-3.0.3\bin)。运行cmd,运行如下命令生成代码:

wsdl2java -all -impl -frontend jaxws21 -encoding utf8  c:/myservice.wsdl   #生成java服务器端和客户端代码,并生成实现类。

  表示使用wsdl生成java代码,-all表示同时生成客户端和服务器端代码; -frontend jaxws21表示 表示兼容jaxs 2.1版本;-encoding utf8 表示代码的编码格式为utf8;c:/myservice.wsdl 表示wsdl文件的地址,也可以是一个网络上的地址。其他命令如下:

wsdl2java -server -impl -frontend jaxws21 -encoding utf8  c:/myservice.wsdl   生成java服务器端代码,并生成实现类。
wsdl2java -client -frontend jaxws21 c:/myservice.xml 生成java客户端代码

cxf构建webservice的两种方式的更多相关文章

  1. java动态获取WebService的两种方式(复杂参数类型)

    java动态获取WebService的两种方式(复杂参数类型) 第一种: @Override public OrderSearchListRes searchOrderList(Order_Fligh ...

  2. WebService的两种方式Soap和Rest比较

    我的读后感:由于第一次接触WebService,对于很多概念不太理解,尤其是看到各个OpenAPI的不同提供方式时,更加疑惑.如google map api采用了AJAX方式,通过javascript ...

  3. WebService的两种方式SOAP和REST比较 (转)

    我的读后感:由于第一次接触WebService,对于很多概念不太理解,尤其是看到各个OpenAPI的不同提供方式时,更加疑惑.如google map api采用了AJAX方式,通过javascript ...

  4. webservice的两种方式SOAP和REST的通俗理解

    Webservice代表所有基于web的服务,包含两种方式SOAP和REST 以SOAP为例: 一个RPC call 就是把一个XML文档post到某个URL下,这个xml文档里写明我要调用的函数名和 ...

  5. 构建Docker镜像两种方式的比较-Dockerfile方式和S2I方式

    前言 写Dockerfile是构建Docker镜像最通常的方式,接触过Docker的童鞋多少了解一些.前段时间研究OpenShift(paas的一种),发现了另外一种构建Docker镜像的方式:S2I ...

  6. [转] 构建Docker镜像两种方式的比较-Dockerfile方式和S2I方式

    原文地址:https://www.cnblogs.com/tianshifu/p/8127837.html 前言 写Dockerfile是构建Docker镜像最通常的方式,接触过Docker的童鞋多少 ...

  7. JS调用webservice的两种方式

    协议肯定是使用http协议,因为soap协议本身也是基于http协议.期中第二种方式:只有webservice3.5以后版本才可以成功 第一种方式:构造soap格式的body,注意加粗的黄色标识,比如 ...

  8. 生成Webservice的两种方式(Axis2,CXf2.x)

    一天之中,用了各种方式生成webservice,就是为了node.js能和程序顺利通信.最终还是用axis2成功了.工作基本完成了,现在可以总结一下. 关于生成方式,推荐使用eclipse,比较方便, ...

  9. WebService的两种方式SOAP和REST有什么不同?

    REST API 优点: 1. 轻量级的解决方案,不必向SOAP那样要构建一个标准的SOAP XML. 2. 可读性比较好:可以把URL的名字取得有实际意义. 3. 不需要SDK支持:直接一个Http ...

随机推荐

  1. 【转】Bloom Filter布隆过滤器的概念和原理

    转自:http://blog.csdn.net/jiaomeng/article/details/1495500 之前看数学之美丽,里面有提到布隆过滤器的过滤垃圾邮件,感觉到何其的牛,竟然有这么高效的 ...

  2. scrum1.4---Sprint 计划

    燃尽图

  3. 控制器中的Action方法,接收浏览器传过来的参数,总共有几种?

    1.根据配置文件中的URL规则 public ActionResult Delete(int id) //id参数就是根据路由里面的参数id来传过来的,这个action方法中的参数一定要和路由中的id ...

  4. Entity FrameWork 延迟加载的本质(一)

    1.集合的标准查询运算符方法,是来自于System.Linq.Enumerable里给IEnumerable接口添加的扩展方法 2.EF上下文里的DBSet<T>里的标准查询运算符方法,来 ...

  5. .NET生成缩略图并下载

    缩略图:比喻一张图片宽度为1000px,大小为800K,经过缩略后变成一张宽度100px,大小10K的图片. 先给出界面: 总体的流程分5步如下图: 1.添加一个html:GetminPic.html ...

  6. c#重点[集合类型]异常,数组,集合ArrayList,List<>,hashTable,hashtable泛型(Dictionary)

    1.foreach[对一些数组或集合进行遍历] foreach(类型 变量名 in 集合对象){语句体} //定义一个数组 ,,,,, }; foreach(var i in sNum1) { Con ...

  7. 发现自己喜欢了移动端开发--Android

    喜欢.net一直到现在了,但是自己做过的项目都不是让我自己很满意,不知道为什么,可能是自己的要求比较高吧! 下面自己记录自己的学习 src专门存放我们java源代码的包 Android 4.2.2存放 ...

  8. mysql=null的优雅解决方法

    对于不是采用所有字段都是not null的mysql表设计而言,mysql提供了一个<=>操作符. 在oracle中我们的处理方式通常类似: where a = #{var} or #{v ...

  9. Android5.0新特性——兼容性(support)

    兼容性 虽然Material Design新增了许多新特性,但是并不是所有新内容对对下保持了兼容. 使用v7包 v7 support libraries r21 及更高版本包含了以下Material ...

  10. GitHub上我收藏Java及Android的项目Demo

    接触编程不久但浏览频率最高的还是GitHub毕竟它真的是程序员必不可少的新世界. (2016/9/23更新) 静态更新,很强势你值得拥有 更新资源不需要重新安装APK (2016.9.10更新) ht ...