我们有一个SpringBoot项目,并且我们正在使用Springfox Swagger生成API文档。
有一个响应类,其中包含:
private Collection<Instant> quartzScheduledDates;
当我运行SwaggerUI时,收到以下消息:
错误路径上的解析器错误。/subscriptions/{subscriptionIdStr}.get.responses.200.schema.properties.quartzScheduledDates.items.$ref由于以下原因而无法解析引用:由于无法解析指针:/ definitions / Instant在文档中不存在
我们正在使用Springfox Swagger 2.9.2,SpringBoot 2.1.2-RELEASE。
我也尝试在springfox中使用Docket技巧,如Springfox文档中所示:
docket.directModelSubstitute(Instant.class, java.util.Date.class);
没有成功-相同的错误消息。
我究竟做错了什么?
这可以通过在为SWAGGER创建Docket时定义新的AlternateTypeRules来解决。
以下是代码段。
Docket docket= new Docket(DocumentationType.SWAGGER_2)
.alternateTypeRules( AlternateTypeRules.newRule(
typeResolver.resolve(Collection.class, Instant.class),
typeResolver.resolve(Collection.class, Date.class), Ordered.HIGHEST_PRECEDENCE))
.select()
.apis(RequestHandlerSelectors.basePackage("com.test"))
.paths(PathSelectors.any())
.build();
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句