हां, अपना खुद का Format
उदाहरण लिखना the recommended approach है। उदाहरण के लिए निम्नलिखित वर्ग को देखते हुए:
case class User(
id: Long,
firstName: String,
lastName: String,
email: Option[String]
) {
def this() = this(0, "","", Some(""))
}
उदाहरण इस प्रकार दिखाई देंगे:
import play.api.libs.json._
implicit object UserFormat extends Format[User] {
def reads(json: JsValue) = User(
(json \ "id").as[Long],
(json \ "firstName").as[String],
(json \ "lastName").as[String],
(json \ "email").as[Option[String]]
)
def writes(user: User) = JsObject(Seq(
"id" -> JsNumber(user.id),
"firstName" -> JsString(user.firstName),
"lastName" -> JsString(user.lastName),
"email" -> Json.toJson(user.email)
))
}
और तुम इस तरह यह प्रयोग करना होगा:
scala> User(1L, "Some", "Person", Some("[email protected]"))
res0: User = User(1,Some,Person,Some([email protected]))
scala> Json.toJson(res0)
res1: play.api.libs.json.JsValue = {"id":1,"firstName":"Some","lastName":"Person","email":"[email protected].com"}
scala> res1.as[User]
res2: User = User(1,Some,Person,Some([email protected]))
अधिक जानकारी के लिए देखें the documentation । अपने स्वयं के स्वरूप [उपयोगकर्ता] लेखन के बिना
implicit val userImplicitWrites = Json.writes[User]
val jsUserValue = Json.toJson(userObject)
:
बढ़िया है, धन्यवाद:
मैं इसे डॉक्स में नहीं मिला है, यहाँ api के लिए कड़ी है! और क्या होगा यदि मैं एक सेक [उपयोगकर्ता] जेसन के रूप में चाहता था? :) – LuxuryMode
Play 'Seq' के लिए एक उदाहरण के साथ आता है, इसलिए आप केवल 'Json.toJson (उपयोगकर्ता) .as [Seq [उपयोगकर्ता]]' का उपयोग कर सकते हैं। –
मोंगो के साथ Play's 'JsNumber' का उपयोग करके, मुझे एक क्रमबद्धता त्रुटि मिलती है:' [त्रुटि] खेल - कार्रवाई का आह्वान नहीं कर सकता है, अंततः एक त्रुटि मिली: java.lang.IllegalArgumentException: कक्षा scala.math.bigDecimal ' –