Play with Scala 中的这些 Json 序列化器让我抓狂。
我已经阅读了数十篇文章、教程和文档。尝试了四种不同的实现读取/写入/格式覆盖的方法,但都无济于事。
所以我放弃了自定义类型并决定变得 super 简单:
def suggest = Action(parse.json) {
request =>
request.body.validate[(String, String)].map {
case (suggestion, categories) => Ok("You suggested " + suggestion + " for categories " + categories)
}.recoverTotal {
e => BadRequest(JsError.toFlatJson(e))
}
}
如主题中所述,错误又回来了。
我真的需要为这样的基本体提供自定义的读取/写入/格式实现吗?
示例输入主体可以是:
{"suggestion":"add generics", "categories":"request;language;updates"}
我错过了什么简单的事情?
最佳答案
玩!为您提供了很多使用 Json 的方法。从代码的外观来看,您正在走元组之路。这基本上可以让您将 Json 转换为元组。您还使用了“读取”,它的缺点是您无法获得精确的错误报告(即:如果传递了无效的 json,您会知道它是无效的……但您不一定知道它为什么无效)。如果您想要更多的错误处理,那么您需要开始使用 'validate' 方法(详细信息在这里:http://www.playframework.com/documentation/2.1.1/ScalaJsonCombinators)。
您可以采用的另一种方法是将 Json 映射到案例类,执行以下操作:
import play.api.libs.json._
case class MyClass(
suggestion: String,
categories: String
)
object MyClass {
implicit val readsMyClass: Reads[MyClass] = new Reads[MyClass] {
def reads(json: JsValue): JsResult[MyClass] = {
for {
suggestion <- (json \ "suggestion").validate[String]
categories <- (json \ "categories").validate[String]
} yield MyClass(json,categories)
}
}
}
这看起来像很多代码,所以 Play 2.1 引入了 Json 'Inception',我还没有尝试( http://www.playframework.com/documentation/2.1.1/ScalaJsonInception )。
最后,如果您想要 Json 验证但不需要编码/解码案例类,那么您可以尝试“海岸到海岸”方法。这会将您的所有 json 保留为 JsObject 类型,但仍会为您提供验证。示例代码在这里:https://github.com/mandubian/play2-json-demo/blob/master/json-coast-to-coast/app/controllers/Application.scala
希望这可以帮助。
关于scala - Play Scala No Json deserializer found for type (String, String)。尝试为这种类型实现隐式读取或格式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16183798/