could not read JSON: Can not construct instance of java.util.Date from String
value '2012-07-21 12:11:12': not a valid representation("yyyy-MM-dd'T'HH:mm:ss.SSSZ", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", "EEE, dd MMM yyyy HH:mm:ss zzz", "yyyy-MM-dd"))
在POJO class.user中将json请求传递给REST控制器方法应该只输入以下日期时间格式,否则它应该抛出message.why DateSerializer没有调用?
add(@Valid @RequestBody User user)
{
}
json:
{
"name":"ssss",
"created_date": "2012-07-21 12:11:12"
}
pojo类变量
@JsonSerialize(using=DateSerializer.class)
@Column
@NotNull(message="Please enter a date")
@Temporal(value=TemporalType.TIMESTAMP)
private Date created_date;
public void serialize(Date value, JsonGenerator jgen, SerializerProvider provider) throws IOException, JsonProcessingException {
logger.info("serialize:"+value);
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
logger.info("DateSerializer formatter:"+formatter.format(value));
jgen.writeString(formatter.format(value));
}
答案 0 :(得分:48)
使用created_date
注释标注您的JsonFormat
字段以指定输出格式。
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = TimeZone.getDefault(), locale = Locale.getDefault())
请注意,如果它们应该基于服务器使用的内容以外的其他内容,则可能需要传入不同的Locale和TimeZone。
您可以在the docs中找到更多信息。
答案 1 :(得分:13)
我有同样的问题,所以我写了一个自定义日期反序列化
与@JsonDeserialize(using=CustomerDateAndTimeDeserialize.class)
public class CustomerDateAndTimeDeserialize extends JsonDeserializer<Date> {
private SimpleDateFormat dateFormat = new SimpleDateFormat(
"yyyy-MM-dd HH:mm:ss");
@Override
public Date deserialize(JsonParser paramJsonParser,
DeserializationContext paramDeserializationContext)
throws IOException, JsonProcessingException {
String str = paramJsonParser.getText().trim();
try {
return dateFormat.parse(str);
} catch (ParseException e) {
// Handle exception here
}
return paramDeserializationContext.parseDate(str);
}
}
答案 2 :(得分:1)
JSON
字符串绑定到日期,则此过程称为deserialization
,而不是serialization
。要将JSON
字符串绑定到日期,请创建自定义日期反序列化,使用
created_date
或其setter
@JsonDeserialize(using=YourCustomDateDeserializer.class)
你需要实现方法public Date deserialize(...)
来告诉杰克逊如何将字符串转换为日期。
享受。
答案 3 :(得分:0)
另一种方法是使用自定义Date对象来处理自己的序列化。
虽然我并不认为扩展像Date
,Long
等简单对象是一种很好的做法,但在这种特殊情况下,它使代码易于阅读,只有一个点,格式已定义,而且与普通Date
对象的兼容性更低。
public class CustomFormatDate extends Date {
private DateFormat myDateFormat = ...; // your date format
public CustomFormatDate() {
super();
}
public CustomFormatDate(long date) {
super(date);
}
public CustomFormatDate(Date date) {
super(date.getTime());
}
@JsonCreator
public static CustomFormatDate forValue(String value) {
try {
return new CustomFormatDate(myDateFormat.parse(value));
} catch (ParseException e) {
return null;
}
}
@JsonValue
public String toValue() {
return myDateFormat.format(this);
}
@Override
public String toString() {
return toValue();
}
}
答案 4 :(得分:0)
我通过以下步骤解决了这个问题。
1。在实体类中,使用@JsonDeserialize对其进行注释
@Entity
@Table(name="table")
public class Table implements Serializable {
// Some code
@JsonDeserialize(using= CustomerDateAndTimeDeserialize.class)
@Temporal(TemporalType.TIMESTAMP)
@Column(name="created_ts")
private Date createdTs
}
答案 5 :(得分:0)
对于某人,如果您使用DTO / VO / POJO映射您的请求,则只需注释日期字段即可
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date customerRegDate;
并且json请求应为:
{
"someDate":"2020-04-04 16:11:02"
}
您不需要注释Entity类变量。