我正在尝试使用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));
}
答案 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。