正确配置swagger后(配置),出现404问题。
如图:

swagger2 404

分析原因

我是在配置完成swagger后正常使用过一段时间的,然后检查了相关配置项的代码,没有被改动过。可以确定swagger的配置没有问题。然后就观察最近项目添加的重要代码及配置。发现最近有添加一个WebConfig。


@Configuration
@EnableWebMvc
public class WebConfig extends WebMvcConfigurerAdapter {
...

    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        List<HttpMessageConverter<?>> convertersList = new HttpMessageConverters().getConverters();
        for (int i = 0; i < convertersList.size(); i++) {
            if (convertersList.get(i) instanceof MappingJackson2HttpMessageConverter) {
                converters.add(getMappingJackson2HttpMessageConverter());
            } else if (convertersList.get(i) instanceof StringHttpMessageConverter) {
                converters.add(getStringHttpMessageConverter());
            } else {
                converters.add(convertersList.get(i));
            }
        }
    }

}

把这个configuration注释掉就可以正常使用了。

原因

@EnableWebMvc会自动生成一个bean,spring boot不会再生成相关的bean。

问题解决

在配置类中加段代码

@Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/**").addResourceLocations("classpath:/static/");
        registry.addResourceHandler("swagger-ui.html")
                .addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**")
                .addResourceLocations("classpath:/META-INF/resources/webjars/");
        super.addResourceHandlers(registry);
    }

相关文章:

  • 2021-07-01
  • 2021-07-16
  • 2022-01-05
  • 2021-11-24
  • 2021-07-02
  • 2021-08-11
  • 2021-04-19
猜你喜欢
  • 2022-01-30
  • 2021-10-25
  • 2022-12-23
  • 2021-07-13
  • 2022-12-23
  • 2021-07-26
  • 2021-12-20
相关资源
相似解决方案