taxeeta
taxeeta

Reputation: 1198

JSON returning null values on response

My response is giving me null values, but when I'm running the same in fiddler, I get a lot of data. I have written very less code and used online tools to generate my code. I wonder where I am messing up.

    Publications response = null ;
    // First open URL connection (using JDK; similar with other libs)
    try {
        URL url = new URL(
                "http://myserver:myport/Mobile/GetPublications");
        HttpURLConnection connection = (HttpURLConnection)url.openConnection() ;
        connection.setDoInput(true);
        connection.setDoOutput(true);
        connection.setRequestMethod("POST") ;
        connection.setRequestProperty("Content-Type", "application/json") ;
        // and other configuration if you want, timeouts etc
        // then send JSON request
        Publications request = new Publications(); // POJO with getters or public fields
        ObjectMapper mapper = new ObjectMapper(); 
        mapper.writeValue(connection.getOutputStream(), request);
        // and read response
        response = mapper.readValue(
                connection.getInputStream(), Publications.class);
    } catch (JsonGenerationException e) {
        e.printStackTrace();
        fail() ;
    } catch (JsonMappingException e) {
        e.printStackTrace();
        fail() ;
    } catch (IOException e) {
        e.printStackTrace();
        fail() ;
    }
    assertNotNull(response) ;
    assertTrue(response.getPublicationInfo() != null) ;
//      assertTrue(response.getPublicationInfo().size() > 0);
//      assertNotNull( ((PublicationInfo)response.getPublicationInfo().get(0)).getPublicationTitle() != null) ;

And the Publications POJO is

import com.fasterxml.jackson.*

@JsonSerialize(include = JsonSerialize.Inclusion.NON_NULL)
@Generated("com.googlecode.jsonschema2pojo")
@JsonPropertyOrder({ "ErrorInfo", "PublicationInfo" })
public class Publications {

@JsonProperty("ErrorInfo")
private Object ErrorInfo;

@JsonProperty("PublicationInfo")
private List<PublicationInfo> PublicationInfo = new ArrayList<PublicationInfo>();
private Map<String, Object> additionalProperties = new HashMap<String, Object>();

@JsonProperty("ErrorInfo")
public Object getErrorInfo() {
    return ErrorInfo;
}

@JsonProperty("ErrorInfo")
public void setErrorInfo(Object ErrorInfo) {
    this.ErrorInfo = ErrorInfo;
}

@JsonProperty("PublicationInfo")
public List<PublicationInfo> getPublicationInfo() {
    return PublicationInfo;
}

@JsonProperty("PublicationInfo")
public void setPublicationInfo(
        List<PublicationInfo> PublicationInfo) {
    this.PublicationInfo = PublicationInfo;
}

@JsonAnyGetter
public Map<String, Object> getAdditionalProperties() {
    return this.additionalProperties;
}

@JsonAnySetter
public void setAdditionalProperties(String name, Object value) {
    this.additionalProperties.put(name, value);
}
}

I get a test case failure at assertTrue(response.getPublicationInfo().size() > 0);. But fiddler returns the following

{
"SpecialPublications": {
    "ErrorInfo": null,
    "SpecialPublicationInfo": [
        {
            "Date": "2/3/2010",
            "URL": "SOME URL HERE",
            "Description": "So much to do so less time."
        },
        {
            "Date": "2/4/2010",
            "URL": "SOME MORE URL HERE",
            "Description": "I need more time"
        }
   ]
}
}

Upvotes: 0

Views: 9571

Answers (1)

Boris Strandjev
Boris Strandjev

Reputation: 46953

You should change @JsonProperty("PublicationInfo") to @JsonProperty("SpotlightPublicationInfo") in all places. You got the attribute name wrong.

The semantics of @JsonProperty is: the attribute name as it appears in the json.

EDIT Also strip the spurious attribute name from the json. Replace:

response = mapper.readValue(connection.getInputStream(), Publications.class);

With:

JsonNode responseJson = mapper.readTree(connection.getInputStream());
response = mapper.readValue(responseJson.traverse().getValueAsString("SpecialPublications"), Publications.class);

This will strip out the spurious {"SpecialPublications": ... } wrapper of the object you try to parse.

Upvotes: 5

Related Questions