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"))
jsonリクエストをRESTに渡す
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));
}
私は同じ問題を抱えているので、@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);
}
}
created_date
フィールドにJsonFormat
注釈を付けて、出力形式を指定します。
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = TimeZone.getDefault(), locale = Locale.getDefault())
サーバーが使用するもの以外のものに基づいている必要がある場合は、異なるLocaleとTimeZoneを渡す必要があることに注意してください。
詳細については、 ドキュメント をご覧ください。
JSON
文字列を日付にバインドする場合、このプロセスはdeserialization
ではなくserialization
と呼ばれます。JSON
文字列を日付にバインドするには、カスタム日付逆シリアル化を作成し、_created_date
_またはそのセッターに注釈を付けます
@JsonDeserialize(using=YourCustomDateDeserializer.class)
public Date deserialize(...)
メソッドを実装して、文字列を日付に変換する方法をJacksonに伝える必要があります。
楽しい。
さらに別の方法は、独自のシリアル化を処理するカスタム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();
}
}
以下の手順を使用してこれを解決しました。
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
}