2

我有一个案例类Ab。

case class Ab(
   startTime: java.sql.Timestamp)

我得到了一个 JSON 表示。

 {"startTime":"2014-12-12 11:12:12"}

Json4s 显然不支持时间戳,所以我创建了一个自定义序列化程序,如:


case object TimestampSerializer extends CustomSerializer[Timestamp](format => (
  {
    case JString(s) => {
      Timestamp.valueOf(s)
    }
    case JNull => null
  },
  {
    case tm: Timestamp => JString(tm.toString())
  }))

但是,当我尝试提取值时,我得到一个映射异常。

我的代码


org.json4s.jackson.JsonMethods.parse(""" {"startTime":"2014-12-12 11:12:12"} """).toString
//JObject(List((startTime,JString(2014-12-12 11:12:12))))
org.json4s.jackson.JsonMethods.parse("""  {"startTime":"2014-12-12 11:12:12"} """).extract[Ab]
//MappingException: No usable value for startTime
//Invalid date '2014-12-12 11:12:12'

像这样编写序列化程序有效:


case object TimestampSerializer extends CustomSerializer[Timestamp](format => (
  {
    case JInt(s) => {
      new Timestamp(s)
    }
    case JNull => null
  },
  {
    case tm: Timestamp => JString(tm.toString())
  }))

4

2 回答 2

5

只需覆盖默认的 dateFormatter。它对我有用。

case class Test(startTime: Timestamp)

implicit val formats = new DefaultFormats {
    override def dateFormatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")
  }

val t1 = parse("""{"startTime":"2014-12-12 11:12:12"}""").extract[Test]
于 2014-12-11T13:14:09.337 回答
1

时间戳扩展 java.util.Date。这意味着不会调用您的自定义序列化程序,而是调用标准日期序列化程序,它使用不同的格式。

我看到了两种解决方案:要么使用自己的时间戳类,要么使用与默认 Date 序列化程序一起使用的不同序列化格式。

于 2014-12-10T20:01:52.267 回答