1

我的要求是我必须从 swagger 定义中生成 springboot 服务器代码。我在下面提到的命令的帮助下生成了代码(使用 swagger-codegen-cli-2.3.1.jar)。

java -jar swagger-codegen-cli-2.3.1.jar generate ^
     -i nycemoves.yml ^
     --api-package com.nyce.moves.api ^
     --model-package com.nyce.moves.model ^
     --invoker-package com.nyce.moves.invoker ^
     --group-id com.nyce.moves ^
     --artifact-id nyce-moves ^
     --artifact-version 0.0.1-SNAPSHOT ^
     -l spring ^
     --library spring-boot ^
     -o nyce-moves

现在,我们已经更新了 swagger 定义并想要重新生成结果模型和 api-invokers,为此我们想使用一个 maven 插件。在浏览了互联网上的各种答案后,我们发现了我们在 pom.xml 中添加的以下构建插件。

<plugin>
            <groupId>io.swagger</groupId>
            <artifactId>swagger-codegen-maven-plugin</artifactId>
            <version>2.3.1</version>
            <executions>
                <execution>
                    <goals>
                        <goal>generate</goal>
                    </goals>
                    <configuration>
                        <inputSpec>src/main/resources/nycemoves.yml</inputSpec>
                        <language>spring</language>
                        <basePackage>${default.package}</basePackage>
                        <modelPackage>${default.package}.model</modelPackage>
                        <apiPackage>${default.package}.api</apiPackage>
                        <invokerPackage>${default.package}.invoker</invokerPackage>
                        <configOptions>
                            <interfaceOnly>true</interfaceOnly>
                            <dateLibrary>java8</dateLibrary>
                            <java8>true</java8>
                            <library>spring-boot</library>
                            <serializableModel>true</serializableModel>
                            <sourceFolder>src/main/java</sourceFolder>                              
                        </configOptions>
                    </configuration>
                </execution>
            </executions>
        </plugin>

现在,当我们执行 mvn clean package 时,我们希望它更新/覆盖所有模型、api 和调用程序。但是,这是行不通的。我们看到了下面提到的异常。

[INFO] 16 errors
[INFO] -------------------------------------------------------------
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 7.516 s
[INFO] Finished at: 2019-03-06T15:05:58+05:30
[INFO] Final Memory: 34M/448M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project nyce-moves: Compilation failure: Compilation failure:
[ERROR] /nyce-moves/src/main/java/com/nyce/moves/api/CommentsApi.java:[29,8] duplicate class: com.nyce.moves.api.CommentsApi
[ERROR] /nyce-moves/target/generated-sources/swagger/src/main/java/com/nyce/moves/model/PostRequest.java:[19,8] duplicate class: com.nyce.moves.model.PostRequest
...

所以,我们实际上需要插件来做以下事情,但我们无法弄清楚。a) 当我们运行 mvn clean package 时,它​​应该在源文件夹和目标文件夹中重新生成服务器存根的所有源代码。b) 如果类已经存在,它应该覆盖它们。我们想稍后在 .swagger-codegen-ignore 的帮助下处理覆盖。

我知道在stackoverflow上有很多关于这个的讨论线程,但我在这里找不到任何可以帮助我的解决方案。请帮助我或将我引导到相关线程。

4

1 回答 1

0

我有同样的问题,我还需要定义输出目录。这是一个片段:

<configuration>
    <language>spring</language>
    <library>spring-cloud</library>
    <configOptions>
        <sourceFolder>swagger</sourceFolder>
        <interfaceOnly>true</interfaceOnly>
        <dateLibrary>java8</dateLibrary>
    </configOptions>
    <output>${project.build.directory}/generated-sources</output>
</configuration>
于 2019-10-15T16:04:12.707 回答