Springboot项目集成Swagger-UI的采坑经历

记录一下集成过程中的采坑经历

Java后台的项目已经完成了,二期添加了app端的需求,所以准备在原项目中集成swagger-ui的时候出现了一些挫折。

1.项目集成完后访问localhost:8080/项目名/swagger-ui.html的时候报404错误

解决方法:添加静态资源访问路径


@Configuration
public class ResourcesConfig extends WebMvcConfigurerAdapter {
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/statics/**").addResourceLocations("classpath:/statics/");
        registry.addResourceHandler("swagger-ui.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
        registry.addResourceHandler("/swagger/**").addResourceLocations("classpath:/statics/swagger/");
    }
}

2.访问swagger-ui.html路径的时候跳转登录页

这个主要是项目中的拦截器的配置,本项目中因添加了shiro拦截器配置,所以这个直接在对应的拦截器中添加swagger-ui路径不拦截即可。

@Bean("shiroFilter")
    public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
        if (UtilValidate.isEmpty(loginpage)) loginpage = "login.html";
        ShiroFilterFactoryBean shiroFilter = new ShiroFilterFactoryBean();
        shiroFilter.setSecurityManager(securityManager);
        shiroFilter.setLoginUrl("/" + loginpage);
        shiroFilter.setUnauthorizedUrl("/");

        Map<String, String> filterMap = new LinkedHashMap<>();

        filterMap.put("/pobstyle.css", "anon");
        filterMap.put("/webjars/**", "anon");
        filterMap.put("/statics/**", "anon");
        filterMap.put("/" + loginpage, "anon");
        filterMap.put("/sys/login", "anon");
        filterMap.put("/favicon.ico", "anon");
        filterMap.put("/captcha.jpg", "anon");

     

        //swagger请求不拦截
        filterMap.put("/swagger/**", "anon");
        filterMap.put("/v2/api-docs", "anon");
        filterMap.put("/swagger-ui.html", "anon");
        filterMap.put("/swagger-resources/**", "anon");
        shiroFilter.setFilterChainDefinitionMap(filterMap);

        filterMap.put("/**", "authc");
        shiroFilter.setFilterChainDefinitionMap(filterMap);
        return shiroFilter;
    }

3.一切都集成好,访问swagger-ui页面的时候,主页面也能出来,但是相关的接口信息一直加载中

fetching resource list: http://localhost:8080/aj/v2/api-docs; Please wait.

这个问题,百度谷歌了一大圈,大多数都说是和fastjson版本有问题,但是本项目的fastjson版本是最新版本,已经不是造成该问题的主要原因。偶然间读到了解决Spring boot中使用Gson,Swagger2 api-docs无法正常显示json问题这个博客才想到查看相关的请求数据:http://localhost:8080/aj/v2/api-docs  浏览器访问项目该路径的时候得到的json数据格式如下:

看到json格式才知道具体的是跟json转换器有关,swagger-ui里正确的json格式是一下格式的

通过对比就会发现swagger页面接口一直加载不出来的原因

本项目中虽然使用了fastjson 但是在相关的配置文件中却使用了GsonHttpMessagConverter导致的,解决方法是:可直接使用默认的MappingJackson2HttpMessageConverter就可以了。

   @Override
    public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
        converters.removeIf(httpMessageConverter -> httpMessageConverter instanceof MappingJackson2HttpMessageConverter); // 删除MappingJackson2HttpMessageConverter
        GsonHttpMessageConverter converter = new GsonHttpMessageConverter();
        converter.setGson(GsonUtils.fetchCommonGson());
        converters.add(converter); // 添加GsonHttpMessageConverter
    }

本项目的解决方法略有不同,因Java后台项目已经完成,修改为默认的json转换器会造成很多问题,后修改了GsonUtils文件,最终的文件内容如下,为解决问题添加了如下的代码(注:其中的Json的包是import springfox.documentation.spring.web.json.Json;)

public class GsonUtils {
	private static final GsonBuilder commonGsonBuilder = createCommonBuilder();

	public static GsonBuilder createCommonBuilder() {
		GsonBuilder gsonBuilder = new GsonBuilder()
				.setPrettyPrinting()
				.disableHtmlEscaping()
				.registerTypeHierarchyAdapter(Date.class, new DateSerializerAndDeserializer())//date
				.registerTypeHierarchyAdapter(Calendar.class, new CalendarSerializer())
				.registerTypeHierarchyAdapter(Timestamp.class, new TimestampSerializer())
				.registerTypeAdapter(Double.class, new JsonSerializer<Double>() {
					@Override
					public JsonElement serialize(Double src, Type typeOfSrc, JsonSerializationContext context) {
						if (src == src.longValue())
							return new JsonPrimitive(src.longValue());
						return new JsonPrimitive(src);
					}
				}).registerTypeAdapter(Long.class, new JsonSerializer<Long>() {
					@Override
					public JsonElement serialize(Long src, Type typeOfSrc, JsonSerializationContext context) {
						if (src != null)
							return new JsonPrimitive(src.toString());
						else
							return new JsonPrimitive("");
					}
				}).registerTypeAdapter(Json.class, new JsonSerializer<Json>() {
					@Override
					public JsonElement serialize(Json json, Type typeOfSrc, JsonSerializationContext context) {
						if (json != null)
							return new JsonParser().parse(json.value());
						else
							return new JsonPrimitive("");
					}
				}).addSerializationExclusionStrategy(new ExclusionStrategy() {
					public boolean shouldSkipField(FieldAttributes fieldAttr) {
						if (fieldAttr.getDeclaredClass().equals(SimpleDateFormat.class)) {
							return true;
						}
						return false;
					}

					public boolean shouldSkipClass(Class<?> clazz) {
						return false;
					}
				}).serializeNulls().disableInnerClassSerialization();

		return gsonBuilder;
	}

	public static Gson fetchCommonGson() {
		return commonGsonBuilder.create();
	}
}

非常感谢解决Spring boot中使用Gson,Swagger2 api-docs无法正常显示json问题这个文章对我的帮助。笔芯。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot项目集成Swagger UI非常简单。以下是一些基本的步骤: 1. 添加Swagger依赖:在项目的`pom.xml`文件中添加Swagger的相关依赖。可以使用以下依赖: ```xml <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency> ``` 2. 创建Swagger配置类:创建一个Java类,用于配置Swagger。可以使用以下示例代码: ```java 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.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; @Configuration @EnableSwagger2 public class SwaggerConfig { @Bean public Docket apiDocket() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.basePackage("com.example.controller")) .paths(PathSelectors.any()) .build() .apiInfo(apiInfo()); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("API Documentation") .description("API Documentation for My Awesome App") .version("1.0.0") .build(); } } ``` 在上述代码中,`@EnableSwagger2`注解启用Swagger,`@Bean`注解创建一个`Docket`实例,配置Swagger的基本信息和扫描的包路径。 3. 启动应用程序:运行Spring Boot应用程序,Swagger UI将在`http://localhost:8080/swagger-ui.html`上自动启动。 现在,您可以在Swagger UI中浏览和测试您的API。Swagger UI将根据您的代码和注释生成API文档,并提供一个交互式的界面,供用户查看和测试API的各个端点和参数。 请注意,上述示例代码中的包路径和其他配置可能需要根据您的项目结构进行调整。此外,还可以通过其他配置选项来自定义Swagger UI的行为和外观。更多详细信息,请参阅Swagger和Springfox的官方文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值