scala調用fastjson JSON.toJSONString()序列化對象出錯


在scala中需要將case class 序列化為string,代碼如下

results.map(JSON.toJSONString(_)).foreach(println) case class pay(id:String)

然后出現下面的錯誤

Error:(35, 12) ambiguous reference to overloaded definition, both method toJSONString in object JSON of type (x$1: Any, x$2: com.alibaba.fastjson.serializer.SerializerFeature*)String and method toJSONString in object JSON of type (x$1: Any)String match argument types (PayTest.this.pay) JSON.toJSONString(t)

查看FastJson toJSONString發現有個可變參數相同的方法,結合錯誤應該是scala不知道調用哪個方法導致的

    public static final String toJSONString(Object object) { return toJSONString(object, new SerializerFeature[0]); } public static final String toJSONString(Object object, SerializerFeature... features) { SerializeWriter out = new SerializeWriter(); try { JSONSerializer serializer = new JSONSerializer(out); for (com.alibaba.fastjson.serializer.SerializerFeature feature : features) { serializer.config(feature, true); } serializer.write(object); return out.toString(); } finally { out.close(); } }

我們直接在代碼指定調用可變參數的方法,SerializerFeature是個枚舉,我們直接選擇第一個

results.map(JSON.toJSONString(_, SerializerFeature.QuoteFieldNames)).foreach(println)

但是出現的結果不是想要的,class的字段都沒有序列化出來

{}

其實fastjson 默認是基於方法clz.getMethods()進行字段查找過濾的,而scala中的getter和setter方法完全不是java那種命名方式。scala中的getter:def foo():T setter: def foo_(val:T):Unit因此如果采用默認配置序列化scala對象,會出現如上問題。但是我們可以加上BeanProperty,目的是讓這個類有getter和setter方法

case class pay(@BeanProperty id:String)

最后結果為

{"id":"1"}

另外我們還有一種基於Jackson的方式

  def objectParse = new RichMapFunction[pay, String] { private var mapper: ObjectMapper = _ override def open(parameters: Configuration): Unit = { this.mapper = new ObjectMapper() } override def map(value: pay): String = { mapper.writeValueAsString(value) } } results.map(objectParse).foreach(println)

 

參考:https://github.com/alibaba/fastjson/issues/1282


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM