我正在按照《 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)的步骤进行操作。我遇到“自定义应用程序”子类的问题,该子类提供了以下示例代码:

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类,而不是直接扩展Application类。问题在于ResourceConfig类本身覆盖了getClasses()方法,并将其声明为final。

您知道有什么方法可以解决此限制吗?

我们的代码:

@ApplicationPath("/")
public class testProj extends ResourceConfig {
    public testProj (){
        property("jersey.config.beanValidation.enableOutputValidationErrorEntity.server", "true");

    }
}


请帮我提供步骤/示例示例/示例代码。

提前致谢。

最佳答案

我在泽西岛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);

10-02 03:22