在phantom-dsl Collection列上使用json4s的JSON序列化程序

时间:2016-03-19 01:51:12

标签: json serialization cassandra json4s phantom-dsl

一直关注需要json序列化程序的集合column tutorial for phantom-dsl

以下实现获得以下错误输出;

  

发现:org.dyne.danielsan.superchain.data.models.JsonVin

     

[error] required:org.json4s.JValue

     

[错误](扩展为)org.json4s.JsonAST.JValue

     

[error] compact(render(obj))

指出我出错的地方有任何帮助,非常感谢。问题是AFAIK phantom-dsl需要定义自定义类型,但是json4s需要一个JValue ...

import com.websudos.phantom.CassandraTable
import com.websudos.phantom.dsl._
import org.json4s.{NoTypeHints, _}
import org.json4s.jackson.JsonMethods._
import org.json4s.jackson.Serialization

case class Transaction(blockhash: String,
                       blocktime: Long,
                       confirmations: Int,
                       vout: List[Vout],
                       vin: List[Vin])

case class JsonVout(value: String,
                    n: String,
                    scriptPubKey: String)

case class JsonVin(coinbase: String,
                   sequence: String)

sealed class TransactionColumnFamily extends CassandraTable[TransactionColumnFamily, Transaction] {

  implicit val formats = Serialization.formats(NoTypeHints)

  override def fromRow(row: Row): Transaction = {
    Transaction(
      blockhash(row),
      blocktime(row),
      confirmations(row),
      vout(row),
      vin(row)
    )
  }

  object blockhash extends StringColumn(this) with PartitionKey[String]

  object blocktime extends LongColumn(this) with ClusteringOrder[Long] with Descending

  object confirmations extends IntColumn(this) with ClusteringOrder[Int] with Descending

  object vout extends JsonListColumn[TransactionColumnFamily, Transaction, Vout](this) {
    override def fromJson(obj: String): Vout = {
      parse(obj).extract[Vout]
    }

//This is where the first error arises

    override def toJson(obj: Vout): String = {
      compact(render(obj))
    }
  }

  object vin extends JsonListColumn[TransactionColumnFamily, Transaction, Vin](this) {
    override def fromJson(obj: String): Vin = {
      parse(obj).extract[Vin]
    }

//This is where the second error arises

    override def toJson(obj: JsonVin): String = {
      compact(render(obj))
    }
  }

}   

object TransactionColumnFamily extends TransactionColumnFamily with RootConnector {
  // some more stuff
  // some more stuff

}

校正

感谢Flavian的评论。你是对的。最后,这是使用Json4s所需要的:

  object vout extends JsonListColumn[TransactionColumnFamily, Transaction, Vout](this) {
    override def fromJson(obj: String): Vout = {
      parse(obj).extract[Vout]
    }

    override def toJson(obj: Vout): String = {
      write(obj)
    }
   }

  object vin extends JsonListColumn[TransactionColumnFamily, Transaction, Vin](this) {
    override def fromJson(obj: String): Vin = {
      parse(obj).extract[Vin]
    }

    override def toJson(obj: Vin): String = {
      write(obj)
    }
  }

1 个答案:

答案 0 :(得分:0)

我认为您的问题是compact(render(obj))调用没有按预期工作。虚拟示例基于lift-json库,其中精确方法调用生成字符串。

最有可能的是,您的render()方法需要JValue,因此您需要做的是在调用JValue之前从JsonVin生成compact(render()) 。您可能会导致导入import org.json4s.JsonDSL._,其中应该有针对不同类型对象的render方法。

此外,在使用Jackson序列化程序时,您可能需要提供自定义序列化程序,如here所述。如果可以,只需使用不需要额外步骤的原生文本。