3

我正在Date使用Jerkson Json 库Jackson的包装器)对包含 a 的对象进行序列化:

import com.codahale.jerkson.Json
import java.util.Date

case class JTest(
    val dTest: Date
)

val jt = new JTest(new Date())
println(Json.generate(jt))

结果是:

{"dTest":1353576079168}

有什么办法可以指定格式或覆盖生成函数?

我意识到 Json 没有正确的 Date 类型,因此输出(以毫秒为单位的 unix 时间)是“正确的”。我想将我的日期序列化为ISO 8601(带时间/时区)格式的字符串:2007-04-05T01:12:22+0100,因为它易于解析且易于阅读。Date的 toString 吐出Thu Nov 22 10:27:54 CET 2012

4

1 回答 1

1

这里有两个问题。首先,ISO8601 日期的小问题——这些可以使用 SimpleDateFormat 来实现,例如

import java.text._
import java.util._
val d1 = new Date()
val sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ")
println(sdf.format(d1))

格式化程序将解析和格式化。请记住不要在线程之间共享它(而是始终在使用前在本地范围内创建一个实例),因为它不是线程安全的。

其次,更棘手的问题是在 Jerkson 中自动使用日期。这似乎是 Jerkson 不如 Lift-json 的一个特性。后者允许将自定义解析器/格式化程序代码插入解析层。杰克森没有,我想。

我们只是通过忽略它来绕过这个限制。我们喜欢 Jerkson 的优越性能,所以我们只使用 Long 和 String 进行日期传输,并分别处理解析。例如

case class JTest(val dTest: String) {
  lazy val dTestDate: Date = {
    val sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ")
    sdf.parse(dTest)
  }
}
于 2012-11-23T08:30:48.147 回答