簡體   English   中英

沒有找到類型為reactmongo.play.json.JSONSerializationPack.type的Json序列化程序作為JsObject

[英]No Json serializer as JsObject found for type reactivemongo.play.json.JSONSerializationPack.type

我將Play框架2.5.3與反應式mongoDB結合使用。

import javax.inject._

import model._
import play.api.Logger
import play.api.libs.json._
import play.api.mvc._
import play.modules.reactivemongo._
import reactivemongo.api.ReadPreference
import reactivemongo.play.json._
import reactivemongo.play.json.collection._

import scala.concurrent.{ExecutionContext, Future}


class InsertController @Inject()(val reactiveMongoApi: ReactiveMongoApi)(implicit exec: ExecutionContext) extends Controller with MongoController with ReactiveMongoComponents {

def dataFuture: Future[JSONCollection] = database.map(_.collection[JSONCollection]("data"))

def createFromJson = Action.async(parse.json) { request =>
Json.fromJson[jsonWrapper](request.body) match {
  case JsSuccess(data, _) =>
    for {
      data <- dataFuture
      lastError <- data.insert(data)
    } yield {
      Logger.debug(s"Successfully inserted with LastError: $lastError")
      Ok("Inserted into db")

    }
  case JsError(errors) =>
    Future.successful(BadRequest("Something went wrong"))
}
}

這是我的控制器,在編譯時出現以下異常:

[info] Compiling 6 Scala sources and 1 Java source to /home/***/target/scala-2.11/classes...
[error] /home/***/app/controllers/InsertController.scala:38: No Json serializer as JsObject found for type reactivemongo.play.json.JSONSerializationPack.type. Try to implement an implicit OWrites or OFormat for this type.
[error]           lastError <- data.insert(data.pack)
[error]                                   ^
[error] one error found
[error] (compile:compile) Compilation failed
[info] Compiling 6 Scala sources and 1 Java source to /home/***/target/scala-2.11/classes...
[error] /home/***/app/controllers/InsertController.scala:38: No Json serializer as JsObject found for type reactivemongo.play.json.JSONSerializationPack.type. Try to implement an implicit OWrites or OFormat for this type.
[error]           lastError <- data.insert(data.pack)
[error]                                   ^
[error] one error found
[error] (compile:compile) Compilation failed
[error] application - 

! @705di1397 - Internal server error, for (GET) [/] ->

play.sbt.PlayExceptions$CompilationException: Compilation error[No Json serializer as JsObject found for type reactivemongo.play.json.JSONSerializationPack.type. Try to implement an implicit OWrites or OFormat for this type.]
    at play.sbt.PlayExceptions$CompilationException$.apply(PlayExceptions.scala:27)
    at play.sbt.PlayExceptions$CompilationException$.apply(PlayExceptions.scala:27)
    at scala.Option.map(Option.scala:145)
    at play.sbt.run.PlayReload$$anonfun$taskFailureHandler$1.apply(PlayReload.scala:49)
    at play.sbt.run.PlayReload$$anonfun$taskFailureHandler$1.apply(PlayReload.scala:44)
    at scala.Option.map(Option.scala:145)
    at play.sbt.run.PlayReload$.taskFailureHandler(PlayReload.scala:44)
    at play.sbt.run.PlayReload$.compileFailure(PlayReload.scala:40)
    at play.sbt.run.PlayReload$$anonfun$compile$1.apply(PlayReload.scala:17)
    at play.sbt.run.PlayReload$$anonfun$compile$1.apply(PlayReload.scala:17)

它建議為JSONCollection編寫一個Owrites或OFormat,這是reactmongo.play.json._包的一部分,據我所知應該已經定義了這些。

這是我的jsonWrapper類:

case class jsonWrapper(tables : tables, userId : String)


object jsonWrapper{
  implicit val jsonRead: Reads[jsonWrapper] = (
    (JsPath \ "tables").read[tables] and
      (JsPath \ "userID").read[String]
    )(jsonWrapper.apply _)

  implicit val jsonWrites: Writes[jsonWrapper] = (
    (JsPath \ "tables").write[tables] and
      (JsPath \ "userID").write[String]
    )(json => (json.tables, json.userId))

  implicit val jsonWrapperFormat : Format[jsonWrapper]  = Json.format[jsonWrapper]

}

表類還具有隱式定義的格式,即讀取和寫入。

我最初使用此示例開始: https : //github.com/jonasanso/play-reactive-mongo-db#master ,它可以工作,但是當我嘗試使其適應我的需要時(例如,使用jsonWrapper類),我就開始了此錯誤,不明白為什么它不起作用。

非常感謝,

彼得·M

我發現了我的錯誤。

def createFromJson = Action.async(parse.json) { request =>
Json.fromJson[jsonWrapper](request.body) match {
  case JsSuccess(data, _) =>
    for {
      data <- dataFuture
      lastError <- data.insert(data)
    } yield {
      Logger.debug(s"Successfully inserted with LastError: $lastError")
      Ok("Inserted into db")

    }
  case JsError(errors) =>
    Future.successful(BadRequest("Something went wrong"))
}

我的案例條目會啟動一個名為“ data”的對象,隨后我將其覆蓋為我的dataFuture對象。 因此,導致錯誤。 我只需要更改變量名...

我有點傻。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM