在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]
答案 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"}""")
}