下面再次是我在上一篇文章中介绍的案例类......但使用cmbaxter建议的修复:
case class User(
id: Option[BSONObjectID],
name: String,
addresses: Option[List[BSONObjectID]]
)
object User {
implicit object UserWriter extends BSONDocumentWriter[User] {
def write(user: User) = BSONDocument(
"_id" -> user.id.getOrElse(BSONObjectID.generate),
"name" -> user.name,
"addresses" -> user.addresses
)
}
implicit object UserReader extends BSONDocumentReader[User] {
def read(doc: BSONDocument) = User(
doc.getAs[BSONObjectID]("_id"),
doc.getAs[String]("name").get,
doc.getAs[List[BSONObjectID]]("addresses")
)
}
}
现在我正在尝试实现一个 Play 控制器来验证传入的 Json 并将其保存到数据库(MongoDB)中。下面是我的代码:
object Users extends Controller with MongoController {
private def collection = db.collection[JSONCollection]("users")
def create = Action.async(parse.json) { request =>
request.body.validate[User].map { user =>
collection.insert(user).map { lastError =>
Logger.debug(s"Successfully inserted with LastError: $lastError")
Created
}
}.getOrElse(Future.successful(BadRequest("invalid json")))
}
}
上面的代码无法编译,因为编译器没有找到任何 Json 反序列化器:
[error] /home/j3d/Projects/test/app/controllers/Users.scala:44: No Json deserializer found for type models.User. Try to implement an implicit Reads or Format for this type.
[error] request.body.validate[User].map { user =>
[error] ^
是否可以重用我在伴随对象中定义的BSONDocumentWriter
and而不是实现and ?BSONDocumentReader
User
Reads
Writes