java - Spring Boot - Swagger - Swagger 不会将标准值更改为多模块项目的 ApiInfo/GlobalResponse

标签 java spring spring-boot swagger

首先,提前感谢所有回复。

现在让我们继续讨论这个问题。今天,我为一个 Spring Boot 项目安装了所有 3.0.0 Swagger 依赖项(boot-starter、swagger2 和 swagger-ui)。一切正常,但我无法更改 Docket 生成器中的 apiInfo 信息。

Gradle :

    implementation "io.springfox:springfox-boot-starter:3.0.0"
    implementation "io.springfox:springfox-swagger2:3.0.0"
    implementation "io.springfox:springfox-swagger-ui:3.0.0"

SpringFoxConfig.java:

package io.ubivis.swagger;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

@Configuration
public class SpringFoxConfig {
    @Bean
    public Docket api() {
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
                .apis(RequestHandlerSelectors.any())
                .paths(PathSelectors.any())
                .build()
                .apiInfo(metaData());
    }

    private ApiInfo metaData() {
        return new ApiInfoBuilder()

                .title("Spring Boot REST API")
                .description("Spring Boot REST API for Space Study")
                .version("1.0.0")
                .license("Apache 2.0")
                .contact(new Contact("XYZ", "XYZ.com", "XYZ@gmail.com"))
                .licenseUrl("http://www.apache.org/licenses/LICENSE-2.0")
                .build();
    }
}

即使在 Docket 构建器中调用元数据函数,Swagger just ignores it and doesn't change any of the default information .

有人知道怎么解决吗?谢谢!

编辑:

刚刚意识到我无法更改任何默认值。即使我尝试更改 GlobalResponseMessage:

    @Bean
    public Docket api() {
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
                .apis(RequestHandlerSelectors.any())
                .paths(PathSelectors.any())
                .build()
                .useDefaultResponseMessages(false)
                .globalResponseMessage(RequestMethod.POST, responseMessageForGet())
                .apiInfo(metaData());
    }

没有任何反应,页面继续显示默认的 globalResponseMessage。

在这次编辑中,我尝试将依赖降级到 2.9.2 版本,寻找我的问题在哪里。但我仍然遇到同样的问题(现在又遇到了一个问题,哈哈)。

最佳答案

刚刚找到了我的问题的答案。其实一开始我忘了说我的项目是一个多模块的spring项目。我不认为这会改变问题的任何内容,但我错了。问题是我的 SpringApplication 没有扫描类 SwaggerConfiguration。

如果您有任何类似的问题,您应该将此注释插入到您的 SpringBootApplication 中:

@SpringBootApplication(scanBasePackages = "br.com.vicnetto")
@EnableSwagger2
public class SpringBootApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConsoleConfigApplication.class, args);
    }
}

@SpringBootApplication 的参数 scanBasePackages 应该包括 SwaggerConfiguration 类。

而第二个注解@EnableSwagger2需要在@SpringBootApplication上下文中(仅适用于3.0.0以下的Swagger版本)

关于java - Spring Boot - Swagger - Swagger 不会将标准值更改为多模块项目的 ApiInfo/GlobalResponse,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68387086/

相关文章:

java - Spring FileInputStream 缓冲区偶尔包含不正确的字符

java - 如何使用现有对象作为构造函数参数在 spring 中实例化 bean

java - Angular 如何知道要调用哪个 Spring Boot REST API?

java - SeekBar 设置 Max 和设置 Progress 的空指针异常

java - listFiles 不返回文件,只返回顶级文件夹

spring - Groovy + Spring - 没有样板(构造函数)代码的 DI

spring - 是否可以在 spring boot 中使用 @Transactional 和 kotlin 协程?

java - 如何断言SpringFramework的org.springframework.http.ResponseEntity类设置的 "Content-Type"?

java - 是否有跨操作系统在 Eclipse 中调试 Java 进程的指南?

java - 获取空对象引用但 ArrayList 已初始化