spring - Swagger codegen - 更改 api 和 Controller 类名称

标签 spring rest swagger

我正在尝试使用 swagger 为 spring 生成剩余代码。目前生成的api是V10Api.java,controller是V10ApiController.java。我希望自定义前缀为“ReadApi.java”和“ReadApiController.java”。

我看了解决方案here实现这个,所以我的代码是:

public class ReadApiSpringCodeGen extends SpringCodegen
{
    static {
        PREFIX="Read"; //compile error at PREFIX
    }
}

它在 PREFIX 处给出了编译错误,所以我猜测 PREFIX 不在父类(super class)中。

我修改了类以结束 toApiName() 方法:

public class ReadApiSpringCodeGen extends SpringCodegen
{
    @Override
    public String toApiName(String name) {
        System.out.println("Name in is ["+name+"]");
        if (name.length() == 0) {
            return "DefaultApi";
        }
        name = sanitizeName(name);
        return camelize(name) + "Read";
    }

   public static void main(String[] args)
   {
       System.out.println("Main called");
   }
}

当运行代码生成器时:

${JAVA_HOME}/bin/java -cp .:./swagger-codegen-cli-2.2.1.jar \
-jar swagger-codegen-cli-2.2.1.jar generate \
    -i Read.yaml \
    -l com.foo.swag.codegen.swagger.ReadApiSpringCodeGen \
....

我得到错误:

Exception in thread "main" java.lang.RuntimeException: Can't load config class with name com.foo.swag.codegen.swagger.ReadApiSpringCodeGen Available: android
ndroid
aspnet5
async-scala
cwiki
csharp
cpprest
.....
at io.swagger.codegen.CodegenConfigLoader.forName(CodegenConfigLoader.java:31)
at io.swagger.codegen.config.CodegenConfigurator.toClientOptInput(CodegenConfigurator.java:353)
at io.swagger.codegen.cmd.Generate.run(Generate.java:221)
at io.swagger.codegen.SwaggerCodegen.main(SwaggerCodegen.java:36)
Caused by: java.lang.ClassNotFoundException: com.foo.swag.codegen.swagger.ReadApiSpringCodeGen
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:264)
at io.swagger.codegen.CodegenConfigLoader.forName(CodegenConfigLoader.java:29)
... 3 more

最佳答案

你必须覆盖方法 apiFilename - 像这样:

@Override
public String apiFilename(final String templateName, final String tag) {
    final String pathWithFile = super.apiFilename(templateName, tag);
    final String pathWithoutFileExtension = pathWithFile.substring(0, pathWithFile.lastIndexOf('.')); //without .java
    final int index = pathWithoutFileExtension.lastIndexOf('.');
    final String className = ".Read" + pathWithoutFileExtension.substring(index+1) + ".java";
    result pathWithoutFileExtension.substring(0, pathWithoutFileExtension.lastIndexOf('.')) + className;
}

关于spring - Swagger codegen - 更改 api 和 Controller 类名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44395192/

相关文章:

java - 如何将库中的值连接为默认值并在应用程序显式定义属性后覆盖它

java - org.hibernate.QueryParameterException : could not locate named parameter

java - 简单的 Spring REST 测试抛出 HttpMediaTypeNotSupportedException

php - REST with PHP如何将URL映射到后端数据库

java - swagger-maven-plugin 不会为单个请求映射生成 "paths"元素

enums - 在 OpenAPI (Swagger) 中重用枚举的子集

mysql - JPA 和 Hibernate - 复合主键与外键

web-services - 将旧式RPC样式服务切换到REST有什么好处?

c# - 我应该选择哪种格式来请求 C# 中的 API - JSON 或 XML

asp.net-web-api - 通过 Swagger 将 XML 字符串发布到 WebAPI