Sto provando a serializzare/deserializzare alcune case classes a/da Json ... e ho problemi quando si tratta di case classes con un solo campo (sto usando Giocare 2.1):Come serializzare/deserializzare le classi di casi da/a Json in Play 2.1
import play.api.libs.json._
import play.api.libs.functional.syntax._
case class MyType(type: String)
object MyType {
implicit val myTypeJsonWrite = new Writes[MyType] {
def writes(type: MyType): JsValue = {
Json.obj(
"type" -> MyType.type
)
}
}
implicit val myTypeJsonRead = (
(__ \ 'type).read[String]
)(MyType.apply _)
}
il codice di cui sopra sempre genera il seguente messaggio di errore:
[error] /home/j3d/Projects/test/app/models/MyType.scala:34: overloaded method value read with alternatives:
[error] (t: String)play.api.libs.json.Reads[String] <and>
[error] (implicit r: play.api.libs.json.Reads[String])play.api.libs.json.Reads[String]
[error] cannot be applied to (String => models.MyType)
[error] (__ \ 'method).read[String]
[error] ^
lo so ... una classe case che contiene solo una stringa non ha molto senso ... ma ho bisogno di serializzare/deserializzare una classe di case molto simile a quella descritta sopra che proviene da una esterna l biblioteca.
Qualche idea? Mi sto perdendo qualcosa? Qualsiasi aiuto sarebbe molto apprezzato ... sto diventando pazzo :-(Grazie.
fare riferimento http://stackoverflow.com/a/20130414/1435971 per esempio per convertire JSON a Scala caso classe – prarthan