gpt4 book ai didi

scala - Play Scala No Json deserializer found for type (String, String)。尝试为这种类型实现隐式读取或格式

转载 作者:行者123 更新时间:2023-12-03 23:53:28 24 4
gpt4 key购买 nike

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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com