使用Jackson重载方法将JSON反序列化为对象

时间:2011-06-14 15:24:15

标签: java json jackson

我正在尝试使用Jackson反序列化存储在CouchDb中的JSON对象。此对象需要反序列化为包含重载方法的pojo。当我尝试从沙发中检索对象并进行反序列化时,我得到以下异常:

  

org.ektorp.DbAccessException:   org.codehaus.jackson.map.JsonMappingException:   冲突的setter定义   财产“乘数”:   com.db.commodities.framework.sdos.model.security.EqOpt#setMultiplier(1   params)vs   com.db.commodities.framework.sdos.model.security.EqOpt#setMultiplier(1   PARAMS)

我试图注释我希望杰克逊使用的二传手,但这似乎没有用。

@JsonProperty("multiplier")
public void setMultiplier(SDOSAttribute multiplier) {
     this.multiplier = multiplier;
}

public void setMultiplier(double multiplier) {
     this.multiplier.setValue(String.valueOf(multiplier));
}

如何配置Jackson以使用特定方法正确反序列化?或者我是以错误的方式处理这个问题?

修改

我做了以下更改。这似乎有效,但有点丑陋。如果有人有更好的方法做到这一点,请随意分享,我很乐意接受。

@JsonProperty("multiplier")
protected void setMultiplierAttribute(SDOSAttribute multiplier) {
    this.multiplier = multiplier;
}

@JsonIgnore
public void setMultiplier(double multiplier) {
    this.multiplier.setValue(String.valueOf(multiplier));
}

3 个答案:

答案 0 :(得分:49)

没有必要更改setter方法的名称以避免歧义。你在@JsonIgnore处于正确的轨道上。对于要忽略的所有同名方法的@JsonIgnore,要使用的方法不需要@JsonProperty注释。

这是一个简单的例子来证明这一点。

input.json: {"value":"forty-two"}

<强> Foo.java:

import java.io.File;

import org.codehaus.jackson.annotate.JsonIgnore;
import org.codehaus.jackson.map.ObjectMapper;

public class Foo
{
  String value;

  public String getValue() {return value;}
  public void setValue(String value) {this.value = value;}

  @JsonIgnore
  public void setValue(int value) {this.value = String.valueOf(value);}

  public static void main(String[] args) throws Exception
  {
    ObjectMapper mapper = new ObjectMapper();
    Foo foo = mapper.readValue(new File("input.json"), Foo.class);
    System.out.println(mapper.writeValueAsString(foo));
  }
}

如果您不想使用Jackson注释更改原始POJO defs,则可以使用MixIn

import java.io.File;

import org.codehaus.jackson.annotate.JsonIgnore;
import org.codehaus.jackson.map.ObjectMapper;

public class Foo
{
  String value;

  public String getValue() {return value;}
  public void setValue(String value) {this.value = value;}
  public void setValue(int value) {this.value = String.valueOf(value);}

  public static void main(String[] args) throws Exception
  {
    ObjectMapper mapper = new ObjectMapper();
    mapper.getDeserializationConfig().addMixInAnnotations(Foo.class, IgnoreFooSetValueIntMixIn.class);
    Foo foo = mapper.readValue(new File("input.json"), Foo.class);
    System.out.println(mapper.writeValueAsString(foo));
  }
}

abstract class IgnoreFooSetValueIntMixIn
{
  @JsonIgnore public abstract void setValue(int value);
}

答案 1 :(得分:6)

杰克逊&gt; 2.4直接使用:

mapper.addMixIn(Foo.class, IgnoreFooSetValueIntMixIn.class);

答案 2 :(得分:2)

如果@JsonIgnore没有帮助(我目前有这种情况,但我仍然不确定原因),也可以使用@XmlTransient。