2016-02-16 4 views
5

Ich habe ein Problem, wenn Sie versuchen, die "auswählbare Entitätsfilterung" einzurichten. Ich habe eine abstrakte Klasse, wie man folgenden:Jersey Jackson Datenentitätsfilterung JsonMappingException bei Sammlung

// In your Pom 
    <dependency> 
     <groupId>org.glassfish.jersey.ext</groupId> 
     <artifactId>jersey-entity-filtering</artifactId> 
    </dependency> 
.... 

    //Somewhere in resourceConfig: Register entity-filtering selectable feature. 
    register(SelectableEntityFilteringFeature.class); 
    property(SelectableEntityFilteringFeature.QUERY_PARAM_NAME, "select"); 

    register(JacksonFeature.class); 

... ..

vor der „auswählbare Einheit Filterung“ Registrierung alle funktionieren gut, ich, dass eine Menge getestet.

Und nach „auswählbare Einheit Filterung“ Ich habe die folgenden Fehler Registrierung:

[2016-02-15 17:25:36] - DEBUG EntityMapper:116 [http-bio-8080-exec-3] Preparing query INSERT INTO 
[2016-02-15 17:25:43] - ERROR JsonMappingExceptionMapper:29 [http-bio-8080-exec-3] Malformed Json! 
com.fasterxml.jackson.databind.JsonMappingException: Can not resolve PropertyFilter with id 'java.util.HashMap'; no FilterProvider configured 
    at com.fasterxml.jackson.databind.ser.std.StdSerializer.findPropertyFilter(StdSerial izer.java:285) 
    at com.fasterxml.jackson.databind.ser.std.MapSerializer.serialize(MapSerializer.java:459) 
    at com.fasterxml.jackson.databind.ser.std.MapSerializer.serialize(MapSerializer.java:29) 
    at com.fasterxml.jackson.databind.ser.DefaultSerializerProvider.serializeValue(DefaultSerializerProvider.java:129) 
    at com.fasterxml.jackson.databind.ObjectWriter.writeValue(ObjectWriter.java:851) 
    at com.fasterxml.jackson.jaxrs.base.ProviderBase.writeTo(ProviderBase.java:650) 
    at org.glassfish.jersey.jackson.internal.FilteringJacksonJaxbJsonProvider.writeTo(FilteringJacksonJaxbJsonProvider.java:135) 
    at org.glassfish.jersey.message.internal.WriterInterceptorExecutor$TerminalWriterInterceptor.invokeWriteTo(WriterInterceptorExecutor.java:265) 
    at org.glassfish.jersey.message.internal.WriterInterceptorExecutor$TerminalWriterInterceptor.aroundWriteTo(WriterInterceptorExecutor.java:250) 
    at org.glassfish.jersey.message.internal.WriterInterceptorExecutor.proceed(WriterInterceptorExecutor.java:162) 
    at org.glassfish.jersey.server.internal.JsonWithPaddingInterceptor.aroundWriteTo(JsonWithPaddingInterceptor.java:106) 
    at org.glassfish.jersey.message.internal.WriterInterceptorExecutor.proceed(WriterInterceptorExecutor.java:162) 
    at org.glassfish.jersey.server.internal.MappableExceptionWrapperInterceptor.aroundWriteTo(MappableExceptionWrapperInterceptor.java:86) 

Es scheint, dass das Problem von dem ich verstehe nicht, warum die Filterung aktiviert

StdSerializer.findPropertyFilter(StdSerializer.java:285) 
    protected PropertyFilter findPropertyFilter(SerializerProvider provider, 
     Object filterId, Object valueToFilter) 
    throws JsonMappingException 
    { 
    FilterProvider filters = provider.getFilterProvider(); 
    // Not ok to miss the provider, if a filter is declared to be needed. 
    if (filters == null) { 
     throw new JsonMappingException("Can not resolve PropertyFilter with id '"+filterId+"'; no FilterProvider configured"); 
    } 
    PropertyFilter filter = filters.findPropertyFilter(filterId, valueToFilter); 
    // But whether unknown ids are ok just depends on filter provider; if we get null that's fine 
    return filter; 
    } 

kommt, sogar in POST-Anfragen? Das Seltsame ist, dass ich den Abfrageparameter "select" nicht in die Anfrage gestellt habe! Könnten Sie bitte helfen?

+0

Das Jackson-Team sagt, dass es ein Problem Jersey ist. https://github.com/jersey/jersey/issues/3574 – ChrisO

Antwort

5

Es scheint, dass, wenn Sie die SelectableEntityFilteringFeature verwenden und wenn Sie in Antwort-Sammlung als Entity setzen, dann werden Sie eine JsonMappingException zu bekommen. Für mich ist es ein Fehler. Die Arbeit ist, sollten Sie Ihre Sammlung in GenericEntity kapseln, um von Jersey-Jackson serialisiert werden zu können.

return Response.status(Status.OK) 
     .entity(new GenericEntity<Set<MyEntity>>(entityIDs)  {}).build(); 
// Use GenericEntity to avoid JsonMappingException because of the new flow with Filtering 
+3

Danke! Dies ist sehr nützlich. Aber leider funktioniert es nicht, wenn die Sammlung nicht das Stammobjekt ist. https://java.net/jira/browse/JERSEY-2933 Ich habe persönlich versucht und ich komme sehr seltsames Verhalten zurück. Ich weiß, es ist ein Jersey-Jackson-Bug, @ user3774109 Glück mit der Auflösung? – aheryan

+0

Als "Trikot" zu Git verschoben wurde, ist über "JERSEY-2933" ein [github] (https://github.com/jersey/jersey/issues/3205) Problem. –

+0

Wrapping in GenericEntity funktionierte nicht für mich, auch wenn die Sammlung das Stammobjekt ist – ChrisO

0

Ich verwende SecurityEntityFilteringFeature, und ich lief auf den gleichen Fehler.

StdSerializer.findPropertyFilter.getFilterProvider und StdSerializer.findPropertyFilter werden null zurückgegeben.

Meine Lösung ist:

@Provider 
public class JsonMappingExceptionOnCollectionResponseFilter implements ContainerResponseFilter { 
@Override 
public void filter(ContainerRequestContext requestCtx, ContainerResponseContext responseCtx) throws IOException { 
    ObjectWriterInjector.set(new ObjectWriterModifier() { 

     @Override 
     public ObjectWriter modify(EndpointConfigBase<?> endpoint, MultivaluedMap<String, Object> responseHeaders, Object valueToWrite, ObjectWriter w, JsonGenerator g) throws IOException { 
      SimpleFilterProvider filterProvider = new SimpleFilterProvider(); 
      SimpleBeanPropertyFilter simpleBeanPropertyFilter = new SimpleBeanPropertyFilter() { 
       @Override 
       protected boolean include(BeanPropertyWriter writer) { 
        return true; 
       } 

       @Override 
       protected boolean include(PropertyWriter writer) { 
        return true; 
       } 
      }; 
      filterProvider.addFilter("your entity class", simpleBeanPropertyFilter); 
      filterProvider.addFilter("your entity class", simpleBeanPropertyFilter); 
      return w.with(filterProvider); 
     } 
    }); 
} 

}

Verwandte Themen