How can I enable MultiPartFeature?

后端 未结 2 1204
攒了一身酷
攒了一身酷 2020-12-11 19:12

My JAX-RS application has an extended Application class.

@ApplicationPath(\"/\")
public class MyApplication extends          


        
相关标签:
2条回答
  • 2020-12-11 19:18

    For me worked like below:

            final ResourceConfig resourceConfig = new ResourceConfig(ApplicationConfig.class);
            resourceConfig.packages("com.econorma.rest");
            resourceConfig.register(MultiPartFeature.class);
    
            ServletHolder jerseyServlet  = new ServletHolder(new ServletContainer(resourceConfig));
    

    This is ApplicationConfig class

    @ApplicationPath("/")
    public class ApplicationConfig extends Application {
    
        @Override
        public Set<Class<?>> getClasses() {
            final Set<Class<?>> resources = new HashSet<Class<?>>();
            resources.add(MultiPartFeature.class);
            resources.add(EntryPoint.class);
            return resources;
        }
    
        @Override
        public Map<String, Object> getProperties() {
            Map<String, Object> properties = new HashMap<String, Object>();
            properties.put("jersey.config.server.provider.packages", "com.econorma.rest");
            return properties;
        }
    }
    
    0 讨论(0)
  • 2020-12-11 19:21

    Not sure why you don't just use a ResourceConfig instead of an Application class. The only reason I can think of is portability, but the use of the Jersey specific multipart feature already breaks that portability.

    But anyway, I'll try to answer this in the "most portable" way. What you can do is set a property, as you would in a web.xml. To set arbitrary properties, you can override

    @Override
    public Map<String, Object> getProperties() {}
    

    in the Application subclass, and set the properties there.

    @Override
    public Map<String, Object> getProperties() {
        Map<String, Object> props = new HashMap<>();
        props.put("jersey.config.server.provider.classnames", 
                "org.glassfish.jersey.media.multipart.MultiPartFeature");
        return props;
    }
    

    This will maintain the classpath scanning for your resources and providers. The scanning is only disabled if you override getClasses() or getSingletons() (and return non-empty sets), but getProperties() is fine.

    Another Option:

    Create a Feature to wrap that feature, and let the feature be discovered, as seen here

    Personally, I would...

    Just use a ResourceConfig, as you're already breaking portability (what's a little more breakage :-)

    @ApplicationPath("/")
    public class AppConfig extends ResourceConfig {
        public AppConfig() {
            packages("packages.to.scan");
            register(MultiPartFeature.class);
        }
    }
    
    0 讨论(0)
提交回复
热议问题