Play Framework 2.2:没有找到Json解串器

tro*_*llr 5 json scala playframework-2.0

我的格式,读取和写入方法不起作用,我无法找到问题.在我看来,我按预期实现了Json.format,Json.reads和Json.writes.如果我编译我的代码,我会收到以下错误:

No Json deserializer found for type Option[(String, String, String, String, String)]
Run Code Online (Sandbox Code Playgroud)

我的型号:

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)
      }
    }
}
Run Code Online (Sandbox Code Playgroud)

我的行动:

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](""))
  }
Run Code Online (Sandbox Code Playgroud)

joh*_*ren 1

Json.toJson[T](obj: T)采用隐式Writes[T]Format[T]实现)。

然后,您将 an 转换Option[User]为 anOption[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"))
}
Run Code Online (Sandbox Code Playgroud)