@JSONField注解
FastJson中的注解@JSONField,一般作用在get/set方法,常用的有以下三个场景:
修改字段映射:
private String name;
// 实体类序列化为json字符串的时候,该类的name字段,序列化为json中的jsonName字段
@JSONField(name="jsonName")
public String getName() {
return name;
}
// json字符串解析为类实体的时候,json中的ne字段,写入此类的name字段
@JSONField(name="ne")
public void setName(String name) {
this.name = name;
}
格式化字段:
@JSONField(format = "yyyy-MM-dd HH:mm:ss")
private Date created_at;
过滤不需要序列化的字段:
@JSONField(serialize = false)
public Integer getAge() {
return age;
}
@JsonFormat和@DateTimeFormat
@JsonFormat :
将Date转换成String,一般用于后台传值给前台:
import com.fasterxml.jackson.annotation.JsonFormat;
// 后台返给前台时, 日期自动格式化
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = “GMT+8”)
private Date go_time;
实体类注解,一般加上时区:timezone = “GMT+8”,因为有时@JsonFormat注解格式化时间会不起作用。
@DatetimeFormat :
将String转换成Date,一般用于前台传值给后台:
import org.springframework.format.annotation.DateTimeFormat;
// 前台传后台时, 字符串自动封装成日期
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date go_time;
小结:
@JsonFormat注解的作用是完成json字符串到java对象的转换工作,与参数传递的方向无关。
@JsonFormat不仅可以完成后台到前台参数传递的类型转换,还可以实现前台到后台类型转换。当content-type为application/json时,优先使用@JsonFormat的pattern进行类型转换。