自定义编码器/解码器,用于解析MongoDB扩展JSON



我正在尝试使用Circe JSON Parser解析MongoDB扩展JSON,在大多数情况下都可以正常工作,除了特殊数据类型,例如。 在下面的案例类中,我有长数据类型的优先级顺序。

case class relinfo(id:String,assetId:String,insureeId:String,queue:String,priorityOrder:Long) extends baseDomain

但是当它被转换为MongoDB JSON格式时,它会被转换为下面描述的特殊mongo格式(检查优先级顺序字段)

{
  "_id" : "4abf009d-64b1-496c-b0e8-9061f5e183a0",
  "id" : "4abf009d-64b1-496c-b0e8-9061f5e183a0",
  "assetId" : "e26d5310-ab0c-4672-9971-4babd3420302",
  "insureeId" : "cdee05a1-a09c-4e10-81df-c3f112298cc3",
  "queue" : "Low",
  "priorityOrder" : {
    "$numberLong" : "1930926795621"
  }
}

挑战在于在反序列化过程中,如果我尝试使用此 JSON 并使用 circe 解析器转换回具体对象类型,那么它将无法映射 priorityOrder 属性,有什么方法可以编写自定义编码器/解码器,以特殊方式处理长数据类型。自定义编码器/解码器将从"$numberLong"嵌套类型读取值,并将该值转换为 Long 数据类型。

我从 circe 解析器中得到这个异常

Left(DecodingFailure(Long, List(El(DownField(priorityOrder),true,false))))

我能够通过为长数据类型创建自定义解码器来找出这个问题的解决方案。这是类似船上个人的代码

  implicit val decodeLong: Decoder[Long] = new Decoder[Long] {
      final def apply(c: HCursor): Decoder.Result[Long] = 
        {
          val longval = c.downField("$numberLong").as[String] match 
          {
            case Right(x) => x.toLong
            case _ => throw new Exception("Unable to find $numberLong")
          }
          Right(longval)  
        }
  }

最新更新