是的,使用JsValue.as[T]
在这种情况下并不稳健:
res0 \ "p"
回报JsUndefined
然后应用于隐式Reads[String]
它说“嘿,这不是一个字符串”......这是真的,但不是你所期望的;)
恕我直言,使用更好的方法Reads
on JsPath
直接地:
scala> ((__ \ "p").read[String]).reads(res0)
res7: play.api.libs.json.JsResult[String] = JsError(List((/p,List(ValidationError(validate.error.missing-path,WrappedArray())))))
scala> ((__ \ "k" \ "m").read[String]).reads(res0)
res8: play.api.libs.json.JsResult[String] = JsError(List((/k/m,List(ValidationError(validate.error.expected.jsstring,WrappedArray())))))
这里你有一个关于丢失路径的更好的消息。
它甚至会通知 JsError 中第一个参数中缺少的路径。
对于好的字符串消息,您可以使用本地消息来映射密钥。
顺便说一句,这些 Json 错误消息相对于 Play 中的其他错误消息(例如 Forms)来说并不完全标准化。我认为我们会在 Play 的未来版本中对其进行改进。
最后,当你想向客户端发送Json验证错误时,有一个辅助函数JsError
与使用JsResult.recoverTotal
scala> ((__ \ "k" \ "m").read[String]).reads(res0).recoverTotal( e => JsError.toFlatJson(e) )
res11: java.io.Serializable = {"obj.k.m":[{"msg":"validate.error.expected.jsstring","args":[]}]}
这只是此类函数的原始版本。如果您需要其他格式,我建议查看 toFlatJson 实现并编写您自己的格式。
玩得开心 ;)