Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Upgrading to Jackson 2.0 from 1.9 in Jersey not working

I'm using Jackson (in Jersey) to serialize entities, and I'm migrating from Jackson 1.9 to 2.0. I followed this guide, and at first it seemed like everything worked out easily.

But a closer look reveals that Jackson 1.9 is still being used to serialize my responses, and therefore ignoring my (migrated) Jackson 2.0 annotation. You can see which annotations I'm using in the following code fragment:

@JsonInclude(JsonInclude.Include.NON_EMPTY)
public abstract class IdEntity {

@Id
@JsonDeserialize(using = ObjectIdJsonDeserializer.class)
protected ObjectId id;

@JsonInclude(JsonInclude.Include.NON_NULL)
@JsonSerialize(using = ObjectIdJsonSerializer.class)
public ObjectId getId() {
    return id;
}

public void setId(ObjectId id) {
    this.id = id;
}

@JsonIgnore
public String getIdAsString() {
    return id == null ? "" : id.toString();
}

My @JsonIgnore getters are getting serialized, and my ObjectIdJsonSerializer isn't being used for the ObjectId field.

In debug I can see that the ObjectMapper being used is from 1.9.

I've removed all the direct maven dependencies to Jackson 1.9, and tried adding exclusions to jersey-json, to prevent it from pulling in Jackson 1.9. But I can't get rid of it entirely (by putting an exclusion to all the codehaus.jackson stuff in my dependency management) because I'm also using Spring AMQP, which needs Jackson 1.9.

Any ideas on how to manage this? Has anyone encountered / solved a similar problem? How do I force Jersey to use Jackson 2.0?

like image 314
Eyal Avatar asked Apr 07 '13 18:04

Eyal


3 Answers

I'm answering my own question, based on the (useful) answers from StaxMan and pgelinas.

I had to do two things to make it work.

The first things was to remove the com.sun.jersey.api.json.POJOMappingFeature from my web.xml.

The second was to update my jackson-jaxrs-json-provider (actually, all of my Jackson artifacts) to 2.1.

With 2.1 or 2.0, and POJOMappingFeature, Jackson 1.9 was still being used for serialization.

With 2.0, and POJOMappingFeature removed, I got a missing message body writer error.

With 2.1 and POJOMappingFeature removed, everything worked as expected.

like image 182
Eyal Avatar answered Sep 23 '22 04:09

Eyal


It is not enough to simply upgrade Jackson core and mapper versions; integration between Jersey (or any JAX-RS implementation) and Jackson happens using specific JAX-RS provider. For Jackson, this would be https://github.com/FasterXML/jackson-jaxrs-json-provider.

So you also need to add 2.x Jackson JAX-RS JSON provider, and that will make Jersey use Jackson 2.x for its operation.

like image 37
StaxMan Avatar answered Sep 24 '22 04:09

StaxMan


I would double-check if you don't have both versions of Jackson in your classpath. The package names in Jackson 2.x got changed to com.fasterxml from org.codehaus. This way you don't have some cryptic classpath problem (like a NoClassDefFound), but if you don't use the proper packages this is the kind of behavior that you'll see.

Also, the annotations were extracted into their own project, jackson-annotations.

like image 26
Pascal Gélinas Avatar answered Sep 25 '22 04:09

Pascal Gélinas