我正在按照Jersey 2.X项目设置指南(https://github.com/swagger-api/swagger-core/wiki/Swagger-Core-Jersey-2.X-Project-Setup-1.5#using-a-custom-application-subclass)执行步骤。我遇到了一个'Custom Application‘子类的问题,它提供了下面的示例代码:
public class SampleApplication extends Application {
@Override
public Set<Class<?>> getClasses() {
Set<Class<?>> resources = new HashSet();
//resources.add(FirstResource.class);
//resources.add(SecondResource.class);
//...
resources.add(io.swagger.jaxrs.listing.ApiListingResource.class);
resources.add(io.swagger.jaxrs.listing.SwaggerSerializers.class);
return resources;
}
}我们的项目偏离了上面提供的示例,因为它扩展了Jersey ResourceConfig类,而不是直接扩展应用程序类。问题是ResourceConfig类本身覆盖了getClasses()方法并将其声明为final。
你知道有什么方法可以绕过这个限制吗?
我们的代码:
@ApplicationPath("/")
public class testProj extends ResourceConfig {
public testProj (){
property("jersey.config.beanValidation.enableOutputValidationErrorEntity.server", "true");
}
}请帮我提供swagger的步骤/示例示例/示例代码?
提前谢谢。
发布于 2018-07-05 20:08:20
我在我的球衣ResourceConfig中使用了一个扩展的BeanConfig类:
public class ExtBeanConfig extends BeanConfig {
Set<Class<?>> resources = new HashSet<Class<?>>();
public ExtBeanConfig(Set<Class<?>> resources) {
super();
if (resources != null) {
this.resources = resources;
}
}
@Override
public Set<Class<?>> classes() {
Set<Class<?>> superClasses = super.classes();
superClasses.addAll(resources);
return superClasses;
}
} 这就是我在ResourceConfig (myClasses是一组带有Swagger注释的类)中配置它的方式:
ExtBeanConfig beanConfig = new ExtBeanConfig(myClasses);
beanConfig.setVersion("1.0.0");
beanConfig.setSchemes(new String[]{"http, https"});
beanConfig.setBasePath("/api");
beanConfig.setScan(true);https://stackoverflow.com/questions/48963633
复制相似问题