我的格式,读取和写入方法不起作用,我无法找到问题。在我看来 我按预期实现了Json.format,Json.reads和Json.writes。如果我编译我的代码,我会收到以下错误:
No Json deserializer found for type Option[(String, String, String, String, String)]
我的模特:
object User {
val simple = {
get[Option[Long]]("id") ~
get[String]("username") ~
get[String]("email") ~
get[String]("firstname") ~
get[String]("lastname") map {
case id ~ username ~ email ~ firstname ~ lastname => User(
id, username, email, firstname, lastname)
}
}
implicit val userFormatter = Json.format[User]
implicit val userReads = Json.reads[User]
implicit val userWrites = Json.writes[User]
def findById(id: Long): Option[User] = {
DB.withConnection {
implicit connection =>
SQL("select * from \"user\" where id = {id}").on('id -> id).as(User.simple.singleOpt)
}
}
}
我的行动:
def get(id: Long) = Action {
Ok(Json.toJson(User.findById(id).map {
user =>
(user.id.toString, user.username, user.email, user.firstname, user.lastname)
}).getOrElse[String](""))
}
答案 0 :(得分:1)
Json.toJson[T](obj: T)
采用隐式Writes[T]
(Format[T]
实现)。
然后将Option[User]
转换为Option[Tuple5[String, String, String, String, String]]
并将其转发给toJson,以便编译器尝试找到这样的格式/写入。可能不是你想要的。
你想要的可能是这样的:
def get(id: Long) = Action {
User.findById(id)
.map(user => Ok(Json.toJson(user)))
.getOrElse(BadRequest(s"Unknown user $id"))
}