我正在使用Java 8,并且我有一个spring控制器,该控制器具有创建新用户的方法:
/**
* Creates a new user in the system
*
* @param username The new user's username
* @param email The new user's email
* @param password The new user's password
* @return the new user
*/
@RequestMapping(value = "/user/create", method = RequestMethod.POST)
@ResponseBody
public String createUser(
@RequestParam(value = "username") String username,
@RequestParam(value = "email") String email,
@RequestParam(value = "password") String password) {
return "";
}
当我为此生成javadocs时,在参数之前会出现大量空白。生成的HTML在列表中的参数之前的
<pre>
标记中具有很多空格。如果我从方法中删除
@RequestMapping
和@ResponseBody
属性,则javadocs会按预期出现。我将来自javadoc工具的结果生成的输出放在以下代码片段中。第一个是今天的渲染方式,第二个是在删除属性后如何正确显示。
<ul class="blockList">
<li class="blockList"><a name="method.detail">
<!-- -->
</a>
<h3>Method Detail</h3>
<a name="createUser-java.lang.String-java.lang.String-java.lang.String-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>createUser</h4>
<pre>@RequestMapping(value="/user/create",
method=POST)
@ResponseBody
public java.lang.String createUser(@RequestParam(value="username")
java.lang.String username,
@RequestParam(value="email")
java.lang.String email,
@RequestParam(value="password")
java.lang.String password)</pre>
<div class="block">Creates a new user in the system</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>username</code> - The new user's username</dd>
<dd><code>email</code> - The new user's email</dd>
<dd><code>password</code> - The new user's password</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the new user</dd>
</dl>
</li>
</ul>
<a name="createUserWithoutAttributes-java.lang.String-java.lang.String-java.lang.String-">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>createUserWithoutAttributes</h4>
<pre>public java.lang.String createUserWithoutAttributes(@RequestParam(value="username")
java.lang.String username,
@RequestParam(value="email")
java.lang.String email,
@RequestParam(value="password")
java.lang.String password)</pre>
<div class="block">Creates a new user in the system</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>username</code> - The new user's username</dd>
<dd><code>email</code> - The new user's email</dd>
<dd><code>password</code> - The new user's password</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the new user</dd>
</dl>
</li>
</ul>
</li>
</ul>
我不知道从哪里开始研究这个问题,因此,我感谢您的投入。
javadoc -J版本说:
java version "1.8.0_40"
Java(TM) SE Runtime Environment (build 1.8.0_40-b26)
Java HotSpot(TM) 64-Bit Server VM (build 25.40-b25, mixed mode)
Javadoc命令:
javadoc -d docs -Xdoclint:none -sourcepath ./MyProject/src -subpackages com -classpath ./spring-web-4.0.8.RELEASE.jar./spring-context-4.0.8.RELEASE.jar
最佳答案
我认为您的问题已在以下JDK错误中得到解决:https://bugs.openjdk.java.net/browse/JDK-8062647
由于上述错误已在Java 9中解决,因此将项目升级到Java 9应该可以解决您的问题。