我有一个非常简单(已存在的)Web服务,我希望使用JDK8生成Web服务客户端。
我使用纯JDK8工具链,这意味着我使用来自我的JDK8目录的wsimport工具。
现在问题来了:JDK8中wsimport工具生成的Java源代码不符合JDK8 Javadoc规范。正如您所知,Javadoc工具在JDK8中变得更加严格。
考虑以下简单模式:
对于此操作,wsimport工具将生成以下Java代码:
问题出在这个类的生成注释上。虽然这种类型的注释在JDK7中可以被Javadoc编译器接受,但在JDK8中不再适用(必须将结尾的 > 替换为
我知道我可以 关闭JDK8中的doclint,但我想知道我是否做错了什么。这只是纯粹的JDK8工具。没有什么花哨的东西。这些工具应该可以一起使用,对吧?并且在被Oracle发布之前已经进行了彻底的测试?所以我认为我做错了什么。比如说什么?
谢谢。
重现步骤: 链接到WSDL(包括模式)
将此文件下载到硬盘的某个位置。
我使用以下命令行来使用
现在在生成的源代码上运行
注意,Javadoc工具也会产生许多警告。我可以接受这一点。但是错误会导致构建失败。
我使用纯JDK8工具链,这意味着我使用来自我的JDK8目录的wsimport工具。
现在问题来了:JDK8中wsimport工具生成的Java源代码不符合JDK8 Javadoc规范。正如您所知,Javadoc工具在JDK8中变得更加严格。
考虑以下简单模式:
<xs:schema version="1.0" targetNamespace="http://mavenwsserver.ws.mytest.org/">
<xs:element name="operation" type="tns:operation"/>
<xs:element name="operationResponse" type="tns:operationResponse"/>
<xs:complexType name="operation">
<xs:sequence>
<xs:element name="person" type="tns:person" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
<xs:complexType name="person">
<xs:sequence>
<xs:element name="firstName" type="xs:string" minOccurs="0"/>
<xs:element name="lastName" type="xs:string" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
<xs:complexType name="operationResponse">
<xs:sequence>
<xs:element name="return" type="xs:string" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
</xs:schema>
对于此操作,wsimport工具将生成以下Java代码:
package org.mytest.ws.mavenwsclient;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlType;
/**
* <p>Java class for person complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="person">
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <sequence>
* <element name="firstName" type="{http://www.w3.org/2001/XMLSchema}string" minOccurs="0"/>
* <element name="lastName" type="{http://www.w3.org/2001/XMLSchema}string" minOccurs="0"/>
* </sequence>
* </restriction>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "person", propOrder = {
"firstName",
"lastName"
})
public class Person {
protected String firstName;
protected String lastName;
/**
* Gets the value of the firstName property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getFirstName() {
return firstName;
}
/**
* Sets the value of the firstName property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setFirstName(String value) {
this.firstName = value;
}
/**
* Gets the value of the lastName property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getLastName() {
return lastName;
}
/**
* Sets the value of the lastName property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setLastName(String value) {
this.lastName = value;
}
}
问题出在这个类的生成注释上。虽然这种类型的注释在JDK7中可以被Javadoc编译器接受,但在JDK8中不再适用(必须将结尾的 > 替换为
>
才能在JDK8中正确)。这些无效注释的结果是构建失败。我知道我可以 关闭JDK8中的doclint,但我想知道我是否做错了什么。这只是纯粹的JDK8工具。没有什么花哨的东西。这些工具应该可以一起使用,对吧?并且在被Oracle发布之前已经进行了彻底的测试?所以我认为我做错了什么。比如说什么?
谢谢。
重现步骤: 链接到WSDL(包括模式)
将此文件下载到硬盘的某个位置。
我使用以下命令行来使用
wsimport
:mkdir D:\JavaDevHG\MavenWSClient\target\generated-sources\jaxws-wsimport
"C:\Program Files\Java\jdk1.8.0_05\bin\wsimport" -keep ^
-s D:\JavaDevHG\MavenWSClient\target\generated-sources\jaxws-wsimport ^
D:/JavaDevHG/MavenWSClient/src/main/wsdl/myWSDL.xml
现在在生成的源代码上运行
javadoc
:"C:\Program Files\Java\jdk1.8.0_05\bin\javadoc" ^
-sourcepath D:\JavaDevHG\MavenWSClient\target\generated-sources\jaxws-wsimport ^
-subpackages org
你会看到类似于这样的内容:
Loading source files for package org.mytest.ws.mavenwsserver...
Constructing Javadoc information...
Standard Doclet version 1.8.0_05
Building tree for all the packages and classes...
Generating .\org\mytest\ws\mavenwsserver\HelloWorldWebService.html...
...
...
Generating .\org\mytest\ws\mavenwsserver\Person.html...
..\..\..\target\generated-sources\jaxws-wsimport\org\mytest\ws\mavenwsserver\Person.java:15: error: bad use of '>'
* <complexType name="person">
^
..\..\..\target\generated-sources\jaxws-wsimport\org\mytest\ws\mavenwsserver\Person.java:16: error: bad use of '>'
* <complexContent>
...
... ^
注意,Javadoc工具也会产生许多警告。我可以接受这一点。但是错误会导致构建失败。