Scala:将case类序列化为JSON,备用名称

问题描述 投票:2回答:2

有什么方法可以将Scala案例类序列化为JSON并且能够提供自定义序列化名称吗?

例如,在Java中,这可以使用Gson库完成:

 public class SomeClassWithFields {
   @SerializedName("name") private final String someField;
   private final String someOtherField;

   public SomeClassWithFields(String a, String b) {
     this.someField = a;
     this.someOtherField = b;
   }
 }

我尝试在Scala中这样做:

case类SomeClassWithFields(@SerializedName(“name”)someField:String)

但似乎没有效果。

有什么想法吗 ?

json scala serialization gson
2个回答
0
投票

你可以用spray-json调用jsonFormat overloads来做到这一点。

以下是它如何与您的示例一起使用:

import spray.json._

case class SomeClassWithFields( someField:String)

object SomeClassJsonProtocol extends DefaultJsonProtocol {
  implicit val someClassFormat = jsonFormat(SomeClassWithFields,"name")
}

0
投票

是的,可以做到。这是如何做:

case class SomeClassWithFields(@(SerializedName @scala.annotation.meta.field)("name") someField:String)

语法很奇怪(注意外部'@'包装了“SerializedName”和scala字段注释)但它工作正常。查看更多详情:https://issues.scala-lang.org/plugins/servlet/mobile#issue/SI-8975

© www.soinside.com 2019 - 2024. All rights reserved.