我有一个案例类Ab。

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


我得到了这个的JSON表示。

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


Json4s显然不支持Timestamp,因此我创建了一个自定义序列化器,例如:

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())
  }))

最佳答案

只是覆盖默认的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]

关于json - Json4s:转换为java.sql.Timestamp不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27408180/

10-09 15:49