当前位置: 首页 > 知识库问答 >
问题:

当Javadoc标记不完整时,Maven无法在Java 8中工作

段干高歌
2023-03-14

自从我使用Maven以来,我已经能够在本地存储库中构建和安装具有不完整Javadoc标记(例如,缺少一个参数)的项目。

但是,自从我迁移到Java 8(1.8.0-EA-B90)以来,Maven对于缺少文档标记是绝对严格的,并且当我试图构建或安装一个Javadoc并不“完美”的项目时,会向我展示大量与Javadoc问题相关的Javadoc错误。我试图在本地存储库中编译和安装的一些项目是我无法控制的第三方项目。因此,在我的场景中,仅仅修复所有这些项目中的所有Javadocs的变通方法似乎是不可行的。

这是我在项目中执行MVN clean package Install时看到的输出的一小部分:

[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 9.026s
[INFO] Finished at: Mon Apr 08 21:06:17 CEST 2013
[INFO] Final Memory: 27M/437M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-javadoc-plugin:2.9:jar (attach-javadocs) on project jpc: MavenReportException: Error while creating archive:
[ERROR] Exit code: 1 - /Users/sergioc/Documents/workspaces/heal/jpc/src/main/java/org/jpc/engine/prolog/PrologDatabase.java:10: error: @param name not found
[ERROR] * @param terms the terms to assert
[ERROR] ^
[ERROR] /Users/sergioc/Documents/workspaces/heal/jpc/src/main/java/org/jpc/engine/prolog/PrologDatabase.java:11: warning: no description for @return
[ERROR] * @return
[ERROR] ^

Javadoc Maven插件在我的POM中配置如下:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-javadoc-plugin</artifactId>
    <version>2.9</version>
    <executions>
        <execution>
            <id>attach-javadocs</id>
            <goals>
                <goal>jar</goal>
            </goals>
        </execution>
    </executions>
</plugin>

就像我之前说的,如果我回到Java七号,一切都很好。也许这是一个与Maven在Java 8中运行有关的bug吗?我怎样才能使它在Java 8中工作(例如,能够构建项目的Javadoc并将其代码安装在我的本地存储库中)呢?我已经在OSX中用Maven 3.0.3和3.0.5进行了测试。

更新:

如果我用 false 更改Javadoc插件配置(谢谢Martin):

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-javadoc-plugin</artifactId>
    <version>2.9</version>
    <executions>
        <execution>
            <id>attach-javadocs</id>
            <goals>
                <goal>jar</goal>
            </goals>
        </execution>
    </executions>
</plugin>

然后将项目安装在我的本地存储库中。但是,仍然没有生成Javadoc JAR。

我在使用这种新配置的控制台中看到的输出片段如下:

[错误]MavenReportException:创建存档时出错:退出代码:1-/Users/....Java:18:警告:no@param...命令行是:/Library/Java/home/bin/javadoc@options@packages

请参阅'/users/sergioc/documents/workspaces/heal/minitoolbox/target/apidocs'目录中生成的Javadoc文件。

在org.apache.maven.plugin.javadoc.abstractjavadocmojo.executejavadoccommandline(abstractjavadocmojo.java:5043)在org.apache.maven.plugin.javadoc.abstractjavadocmojo.executeport(abstractjavadocmojo.java:1990)在org.apache.maven.plugin.javadocjar.execute(javadocjar.java:181)在在org.apache.maven.defaultmaven.doexecute(defaultmaven.java:320)在org.apache.maven.defaultmaven.execute(defaultmaven.java:156)在org.apache.maven.cli.mavencli.execute(defaultmaven.java:537)在org.apache.maven.cli.mavencli.domain(mavencli.java:196)在org.apache.maven.cli.mavencli.domain(mavencli.java:141

关于如何构建源代码、安装项目和生成Javadoc JAR(就像它与Java 7一起工作一样),有什么解决方法吗?

共有3个答案

尉迟国发
2023-03-14

这里是我所知道的忽略doclint警告的最简洁的方法,不管使用的是什么Java版本。不需要在多个配置文件中重复插件配置,只需稍加修改。

<profiles>
  <profile>
    <id>doclint-java8-disable</id>
    <activation>
      <jdk>[1.8,)</jdk>
    </activation>
    <properties>
      <javadoc.opts>-Xdoclint:none</javadoc.opts>
    </properties>
  </profile>
</profiles>

<build>
  <plugins>
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-javadoc-plugin</artifactId>
      <version>2.9.1</version>
      <executions>
        <execution>
          <id>attach-javadocs</id> <!-- The actual id should be apparent from maven output -->
          <configuration>
            <additionalparam>${javadoc.opts}</additionalparam>
          </configuration>
        </execution>
      </executions>
    </plugin>
    ...
  </plugins>
</build>

在Oracle/Open jdk 6、7、8和11上测试

宰父淳
2023-03-14

让Java 8和Java 7都能工作的最简单的方法是在构建中使用一个概要文件:

<profiles>
  <profile>
    <id>doclint-java8-disable</id>
    <activation>
      <jdk>[1.8,)</jdk>
    </activation>

    <build>
      <plugins>
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-javadoc-plugin</artifactId>
          <configuration>
            <additionalparam>-Xdoclint:none</additionalparam>
          </configuration>
        </plugin>
      </plugins>
    </build>
  </profile>
</profiles>
后凯捷
2023-03-14

最好的解决方案是修复javadoc错误。如果由于某种原因,这是不可能的(即:自动生成的源代码),那么您可以禁用此检查。

DocLint是《Java 8》中的一个新特性,概括为:

提供一种方法,在开发周期的早期检测Javadoc注释中的错误,并且以一种很容易链接回源代码的方式检测Javadoc注释中的错误。

默认情况下,这是启用的,并且在生成JavaDocs之前将运行大量的检查。您需要按照本线程中的指定,为Java 8关闭此功能。您必须将此添加到maven配置中:

<profiles>
  <profile>
    <id>java8-doclint-disabled</id>
    <activation>
      <jdk>[1.8,)</jdk>
    </activation>
    <properties>
      <javadoc.opts>-Xdoclint:none</javadoc.opts>
    </properties>
  </profile>
</profiles>
<build>
  <plugins>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-javadoc-plugin</artifactId>
        <version>2.9</version>
        <executions>
            <execution>
                <id>attach-javadocs</id>
                <goals>
                    <goal>jar</goal>
                </goals>
                <configuration>
                    <additionalparam>${javadoc.opts}</additionalparam>
                </configuration>
            </execution>
        </executions>
    </plugin>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-site-plugin</artifactId>
        <version>3.3</version>
        <configuration>
          <reportPlugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-javadoc-plugin</artifactId>
              <configuration>
                <additionalparam>${javadoc.opts}</additionalparam>
              </configuration>
            </plugin>
          </reportPlugins>
        </configuration>
      </plugin>
   </plugins>
</build>

对于maven-javadoc-plugin 3.0.0+:替换

<additionalparam>-Xdoclint:none</additionalparam>

<doclint>none</doclint>
 类似资料:
  • 问题内容: 自从我使用Maven以来,我已经能够在本地存储库中构建并安装具有不完整Javadoc标记(例如,缺少参数)的项目。 但是,由于我迁移到Java 8(1.8.0-ea-b90),因此Maven对丢失文档标记绝对严格,并且在我尝试构建或安装Javadoc不在其中的项目时向我展示许多与Javadoc问题有关的Javadoc错误。 “完善”。我试图编译并安装在本地存储库中的某些项目是我无法控制

  • 我已经从Java7迁移到Java8。当我执行时,我的构建成功。但是当我执行时,站点生成失败,表示: [错误]无法在项目XXXXXX上执行目标org.apache.maven.plugins:maven-site-plugin:3.4:site(default-site):生成maven-javadoc-plugin:2.8:test-javadoc: 下面是我的 我们的测试中有些Javadoc标记

  • 我找不到任何答案,也许有人知道。我试图设置maven站点和maven javadoc插件,但这似乎是不可能的。每次我运行mvn站点:run时,我都会得到这个堆栈跟踪: 而在maven网站上我得到了一堆包不存在的错误。这东西似乎根本不起作用,我尝试了各种配置。前一段时间,我也花了很多时间来尝试这件事的工作,并成功地添加了一些,但它现在不工作。我看起来不可能设置,所以我需要一些帮助,也许我错过了什么。

  • 无法在pom中添加父标记。xml如下所示。它不断给我一个错误,说“Project'org.springframework.boot:springboot:2.3.2.RELEASE'not found检查信息:检查Maven模型的解决问题。”有人能帮忙吗?

  • 您很快就会意识到,JDK8在Javadoc方面要严格得多(默认情况下)。(链接-参见最后一个项目符号) 如果您从未生成任何Javadoc,那么您当然不会遇到任何问题,但是像Maven发布流程这样的事情,可能还有您的CI构建,在使用JDK7时会突然失败。检查Javadoc工具的exit值的任何操作现在都将失败。与JDK7相比,JDK8 Javadoc在方面可能也更冗长,但这不是本文的范围。我们正在讨