本文主要是介绍【日常总结】优雅升级Swagger 2 升至 3.0, 全局设置 content-type application/json,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
一、场景
二、问题
三、解决方案
四、延伸
上一节:【日常总结】Swagger-ui 导入 showdoc (优雅升级Swagger 2 升至 3.0)-CSDN博客
一、场景
接上一节:在 Swagger3Config extends WebMvcConfigurationSupport,来设置Swagger 3.0
的URL映射,发现问题。
二、问题
在Swagger 3.0上调试接口返回为 content-type application/xml
三、解决方案
发现项目中有两个类继承了extends WebMvcConfigurationSupport
-
WebMvcConfig
-
Swagger3Config
方案:去掉 WebMvcConfig 的 extends WebMvcConfigurationSupport,将下面代码迁移至
WebMvcConfig中
@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler("/**").addResourceLocations("classpath:/static/");registry.addResourceHandler("swagger-ui.html").addResourceLocations("classpath:/META-INF/resources/");registry.addResourceHandler("/swagger-ui/**").addResourceLocations("classpath:/META-INF/resources/webjars/springfox-swagger-ui/");registry.addResourceHandler("doc.html").addResourceLocations("classpath:/META-INF/resources/");registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");super.addResourceHandlers(registry);}
四、延伸
如果想要 Swagger 默认返回 content-type application/xml,只需要在
Swagger3Config extends WebMvcConfigurationSupport 并重写 addResourceHandlers即可
这篇关于【日常总结】优雅升级Swagger 2 升至 3.0, 全局设置 content-type application/json的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!