将Json日期和时间字符串解析为Play Framework 2.1中具有日期的案例类

时间:2013-03-28 12:25:23

标签: scala playframework-2.1

在PlayFramework 2.1中我想读取一个json并创建一个case类。结构不同,所以我不能使用默认的阅读器。我需要编写什么来将两个字符串合并到java.util.Date?

import play.api.libs.functional.syntax._
import play.api.libs.json._
import play.api.libs.json.util._
import play.api.libs.json.Reads._

case class Person(name: String, lastSeen: Date)
val jsonString = Json.parse("""{name: "Joe", day: "2013-03-28", time: "09:35"}""")

val personLastSeen: Reads[Person] = (
  (__ \ "name").read[String] ~
  // (__ \ "day").read[String] (__ \ "time").read[String] // @TODO
)(Person)

我应该换掉这个读物吗?我使用val dateStructure = new SimpleDateFormat("yyyy-MM-dd HH:mm")尝试dateStructure.parse(...),但我认为我需要Reads[Date]

1 个答案:

答案 0 :(得分:3)

我认为你不能使用Reads [T]组合子做到这一点,但你可以定义一个特征Reads及其方法def read(json: JsValue): JsResult[T]

import play.api.libs.functional.syntax._
import play.api.libs.json._
import play.api.libs.json.util._
import play.api.libs.json.Reads._
import java.util.Date
import java.text.SimpleDateFormat

case class Person(name: String, lastSeen: Date) {      
}

object Person {
  implicit val personLastSeen = new Reads[Person] {
    val sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm")
    def reads(js: JsValue): JsResult[Person] = {
      JsSuccess(Person(
        (js \ "name").as[String],
        sdf.parse((js \ "day").as[String] + " " + (js \ "time").as[Float])))
    }
  }
}
object Test extends App {
    val jsonString = Json.parse("""{name: "Joe", day: "2013-03-28", time: "09:35"}""")
}