[英]Map JSON to nested case class play framework
我需要接收 Json 數據並將其綁定到在參數中包含其他案例類的案例類。
我什至不知道在控制器中寫什么,文檔中也沒有幫助,我已經到處尋找,但沒有找到任何答案。
以下是案例類:
case class InfoForm(nomEntreprise: String, siren: String, dateCreation: String, entreeRelation: String, secteur: String, cotationBDF: String, montantPrivileges: String, fcc: String, ca: String, resultatBrut: String, ebe: String, totalBilan: String, fp: String)
object InfoForm {
implicit val format = Json.format[InfoForm]
}
case class Associate(tiersAssoc: String, nom: String, prenom: String, birthday: Date)
object Associate {
implicit val assocFormat = Json.format[Associate]
}
case class AssociateForm(nbAssoc: Int, cotation: String, assoc: Seq[Associate], fccAssociate: String, ficp: String)
object AssociateForm {
implicit val format = Json.format[AssociateForm]
}
case class OperationForm(mntAcquisition: String, codePostal: String, typePret: String, mntFinance: String, mensualite: String, loyerPrevisionnel: String)
object OperationForm {
implicit val format = Json.format[OperationForm]
}
case class CompanyForm(sci: Boolean, infoForm: InfoForm, associateForm: AssociateForm, operationForm: OperationForm)
object CompanyForm {
implicit val format = Json.format[CompanyForm]
}
傑森:
{
"sci": true,
"nomEntreprise": "nom entreprise",
"siren": "siren",
"dateCreation": "1977-04-22T01:00:00-05:00",
"entreeRelation": "1977-04-22T01:00:00-05:00",
"secteur": "un secteur",
"cotationBDF": "cotation",
"montantPrivileges": "montant",
"fcc": "fcc",
"ca": "ca c est un option attention",
"resultatBrut": "resultat",
"ebe": "ebe",
"totalBilan": "totalBilan",
"fp": "fp",
"nbAssoc": 1,
"cotation": "une chaine",
"assoc": [
{
"tiersAssoc": "une chaine",
"nom": "name",
"prenom": "prenom",
"birthday":"1977-04-22T01:00:00-05:00"
}
],
"fccAssociate": "une autre chaine",
"ficp": "encore une autre chaine",
"mntAcquisition": "montant acquisition",
"codePostal": "code postal",
"typePret": "typePret",
"mntFinance": "montant finance",
"mensualite": "string",
"loyerPrevisionnel": "derniere !"
}
這是我迄今為止在控制器中嘗試過的:
def setCompanyForm(id: String) = {
Errors.collect {
silhouette.SecuredAction.async { implicit request =>
Errors.handle {
val companyForm = request.body.asJson
companyForm match {
case Some(json) => println(Json.fromJson[CompanyForm](json))
case None => println("rien")
}
Future.successful(Ok(""))
}
}
}
}
我打印時絕對沒有日志。
根據標題,我嘗試幫助您進行 Json 映射:
我創建了一個ScalaFiddle ,所以你可以自己嘗試一下。
我可以開始用一個簡單的字符串替換日期,因為您錯過了日期的格式化程序(並且不清楚您有什么日期)。
所以運行這個是不成功的,因為錯誤的類型:
Json.parse(json).validate[CompanyForm]
修復一切正常后: ScalaFiddle v.2
Json.parse(json).validate[InfoForm]
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.