我正在使用杰克逊2.10.0(https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-core/2.10.0),下面是一个简单的测试用例

Person类的定义如下,对于setter,我使用了@JsonSetter批注,而对于getter没有使用@JsonGetter,

import com.fasterxml.jackson.annotation.JsonProperty;

public class Person {
    private String firstName;
    private String lastName;

    public String getFirstName() {
        return firstName;
    }

    @JsonSetter("first_name")
    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }

    public String getLastName() {
        return lastName;
    }

    @JsonSetter("last_name")
    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

}


然后,我创建一个Person对象,并将其序列化为字符串,

import com.fasterxml.jackson.databind.ObjectMapper;


public class Person3Test2 {
    public static void main(String[] args) throws Exception {
        Person p = new Person();
        p.setFirstName("abc");
        p.setLastName("def");
        String str = new ObjectMapper().writeValueAsString(p);
        System.out.println(str);
    }
}


因为它不使用@JsonGetter,所以它将调用Person的getters,所以我认为输出应为

{"firstName":"abc","lastName":"def"}


但是,我很惊讶地发现它是:

{"first_name":"abc","last_name":"def"}


看来@JsonSetter已影响getter输出,请问这里的行为是什么。

最佳答案

@JsonSetter将在序列化期间生效,here是github问题,如果您想使用其他名称,请在@JsonGetter方法上使用另一个注释get


  文档可能有误; @JsonSetter不仅影响反序列化。尽管确实可以将其用于非对称命名(类似于@JsonProperty本身,带有“ split”注释),但其范围不受限制。
  可能已经到了某个时候,但是在统一属性处理之后(在1.8左右),各种属性访问者之间的分隔变少了。
  
  我可以回顾一下Javadocs,以明确说明注解的范围不受严格限制-某些注解可能仅与一个或另一个相关,而没有一个是有意分离的。

10-02 21:43