比如我想将User对象转换成json数据给前台,但是有一些User的属性我不想给前台,例如密码,创建日期等等
如果你使用的 Spring 版本是 4.1,并且使用 Jackson 处理 Json 序列化,那么解决这个问题非常简单。
以你问题中的例子举例:
Jackson 提供了2种注解来控制 Property 是否包含在序列化的 Json 中。
@Entity
public class User {
private Integer id;
private String name;
@JsonIgnore //输出对象,序列化时忽略改对象
private String password;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
@JsonIgnoreProperties({"password", "createDate"})
public class User {
private String username;
private String password;
private Date createDate;
//...
}
上面示例中,两个注解作用是一样的,你可以根据需要使用 @JsonIgnore 和 @JsonIgnoreProperties。
2:除此之外,Spring 4.1 增加了 Jackson @JsonView 注解的支持,对于个性化输出就更加方便了。
以上面的例子举例,假设A场景,需要输出User时隐藏 password, B场景,需要隐藏name。
3:使用 Jackson 提供的 mix 方案解决,将 JsonView 中的描述抽取到另一个类中