Springboot下swagger-ui.html访问不到的解决方案

作者:牧竹子 时间:2022-08-20 20:52:22 

Springboot swagger-ui.html访问不到

问题

在前面的Swagger2的基本配置中是可以访问到swagger-ui.html的

但当自定义继承配置WebMvcConfigurationSupport后便无法访问到该页面,原因参考请看参考资料。

首先看我的自定义配置,


*************
* HttpMessageConverter转换处理
* 处理转义hmtl标签为正常的hmtl标签
* @author zjcjava@163.com
*
*/
@Configuration
public class WebConfig extends WebMvcConfigurationSupport {
   @Bean
   public MappingJackson2HttpMessageConverter customJackson2HttpMessageConverter() {
       MappingJackson2HttpMessageConverter jsonConverter = new MappingJackson2HttpMessageConverter();
       ObjectMapper objectMapper = new ObjectMapper();
       objectMapper.configure(
               DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
       objectMapper.getSerializerProvider().setNullValueSerializer(
               new JsonSerializer<Object>() {
                   @Override
                   public void serialize(Object value, JsonGenerator jgen,
                           SerializerProvider provider) throws IOException,
                           JsonProcessingException {
                       jgen.writeString("");
                   }
               });
       // 进行HTML解码
       objectMapper.registerModule(new SimpleModule().addSerializer(
               String.class, new JsonSerializer<String>() {
                   @Override
                   public void serialize(String value, JsonGenerator jgen,
                           SerializerProvider provider) throws IOException,
                           JsonProcessingException {
                       jgen.writeString(StringEscapeUtils.unescapeHtml4(value));
                   }
               }));
       jsonConverter.setObjectMapper(objectMapper);
       return jsonConverter;
   }
   @Override
   public void configureMessageConverters(
           List<HttpMessageConverter<?>> converters) {
       converters.add(customJackson2HttpMessageConverter());
       super.addDefaultHttpMessageConverters(converters);
   }
}

如果我把该文件全部注释掉则会正常显示,否则无法访问到swagger-ui.html,

解决方法

如果继承了WebMvcConfigurationSupport,则在配置文件在中配置的相关内容会失效,需要重新指定静态资源

因此参照资料2我做了处理如下,在该代码的末尾加上静态资源配置

代码加在


*************
* HttpMessageConverter转换处理
* 处理转义hmtl标签为正常的hmtl标签
* @author zjcjava@163.com
*
*/
@Configuration
public class WebConfig extends WebMvcConfigurationSupport {
   @Bean
   public MappingJackson2HttpMessageConverter customJackson2HttpMessageConverter() {
       MappingJackson2HttpMessageConverter jsonConverter = new MappingJackson2HttpMessageConverter();
       ObjectMapper objectMapper = new ObjectMapper();
       objectMapper.configure(
               DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
       objectMapper.getSerializerProvider().setNullValueSerializer(
               new JsonSerializer<Object>() {
                   @Override
                   public void serialize(Object value, JsonGenerator jgen,
                           SerializerProvider provider) throws IOException,
                           JsonProcessingException {
                       jgen.writeString("");
                   }
               });
       // 进行HTML解码
       objectMapper.registerModule(new SimpleModule().addSerializer(
               String.class, new JsonSerializer<String>() {
                   @Override
                   public void serialize(String value, JsonGenerator jgen,
                           SerializerProvider provider) throws IOException,
                           JsonProcessingException {
                       jgen.writeString(StringEscapeUtils.unescapeHtml4(value));
                   }
               }));
       jsonConverter.setObjectMapper(objectMapper);
       return jsonConverter;
   }
   @Override
   public void configureMessageConverters(
           List<HttpMessageConverter<?>> converters) {
       converters.add(customJackson2HttpMessageConverter());
       super.addDefaultHttpMessageConverters(converters);
   }
   /**
    * 发现如果继承了WebMvcConfigurationSupport,则在yml中配置的相关内容会失效。 需要重新指定静态资源
    *
    * @param registry
    */
   @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);
   }
   /**
    * 配置servlet处理
    */
   @Override
   public void configureDefaultServletHandling(
           DefaultServletHandlerConfigurer configurer) {
       configurer.enable();
   }
}

swagger-ui的坑,swagger-ui.html无显示

且返回200无报错,且/v2/api-docs可以正常访问

因为粗心,踩中的坑,代码规范,细心真的能节省很多时间

上图,界面显示如图,一切都正常,控制台,也没有报错,很诡异吧

Springboot下swagger-ui.html访问不到的解决方案

Springboot下swagger-ui.html访问不到的解决方案

docs却可以正常访问,包括接口,都是正常的,网上很多解决方案都是说,跨域问题,或者是静态资源访问不到

1,首先跨域问题,会报错,有很明显的报错提示,这里排除,

2,静态资源,可以参考csdn上的其他方案很多,排查方法,可以查看targer目录下是否有静态文件

Springboot下swagger-ui.html访问不到的解决方案

现在说这个问题导致的原因,以及解决方案

由于当时再写 * 相关代码,里面还涉及到过滤器,网上说到swagger会和 * 有冲突,所以一直错误认为是 * 导致的问题,而且还有fastdfs的相关代码,也有说这两个起冲突,没办法,一一排查,进行版本回滚,发现fasdfs这个版本没有问题,这里要说,平时开发一定要切分支,分支切不了也要多提交版本,这样一旦出现问题也好解决。

然后下个版本发现,加上 * ,问题就又出现了,把 * 所有代码注释掉,问题依旧,百思不得其解,无奈,地毯扫描,版本不一样的全部注释,直到注释到controller层,又正常了,非常怀疑,一个controller,service业务代码这些不应该导致出问题的,怎么会是这的问题,然后进入代码准备细查,打开代码惊喜就来了

Springboot下swagger-ui.html访问不到的解决方案

这是代码,本来还准备去看service层,看下是不是业务上有什么代码报错,到这就感觉更奇怪了,什么代码都没写,去掉就正常了,然后搜一下是不是方法名重复了,发现没有,

这时发现:@RequestMapping(),对就是这个注解,里面没东西是什么鬼,估计是当时注释的时候直接给删掉了,加入值后一切恢复正常

Springboot下swagger-ui.html访问不到的解决方案

Springboot下swagger-ui.html访问不到的解决方案

现在想想,swagger本来就是对controller的提取,没有报错就可以怀疑接口问题。

来源:https://blog.csdn.net/zjcjava/article/details/78064264

标签:Springboot,swagger-ui.html,访问
0
投稿

猜你喜欢

  • 对Java中JSON解析器的一些见解

    2023-02-05 20:53:15
  • Spring AOP面向切面编程实现原理方法详解

    2021-07-22 00:26:07
  • c#调用c++的DLL的实现方法

    2023-10-27 05:27:40
  • Java笛卡尔积算法原理与实现方法详解

    2023-11-18 22:08:17
  • Spring整合Quartz实现动态定时器的示例代码

    2022-10-22 06:48:17
  • 浅谈Springboot之于Spring的优势

    2022-01-08 02:35:29
  • java异常处理详细介绍及实例

    2023-11-28 05:07:02
  • Spring基于常用AspectJ切点表达式使用介绍

    2023-12-08 19:58:37
  • 在IDEA里gradle配置和使用的方法步骤

    2023-11-23 16:07:58
  • C# 重写Notification提示窗口的示例代码

    2021-12-26 19:57:59
  • C语言经典指针笔试题详解

    2021-10-23 12:56:39
  • SrpingDruid数据源加密数据库密码的示例代码

    2021-06-21 03:26:26
  • 如何在C# 中查找或结束程序域中的主、子进程

    2023-06-14 20:00:41
  • RocketMQ集群消费与广播消费模式

    2021-10-16 07:20:45
  • C#实现发送手机验证码功能

    2022-01-11 18:49:57
  • SpringBoot整合Shiro的方法详解

    2022-04-13 15:05:56
  • Android13 加强Intent filters 的安全性

    2022-06-17 03:15:55
  • Android缓存机制——LruCache的详解

    2023-07-30 07:26:34
  • C# String Replace高效的实例方法

    2023-10-26 23:24:08
  • MyBatis Generator去掉生成的注解

    2022-08-29 22:01:03
  • asp之家 软件编程 m.aspxhome.com