Проблема: «Извлечение» JSON с помощью lift-json в приложении для Android (Scala) - PullRequest
4 голосов
/ 29 июня 2011

Я хочу десериализовать JSON-String с помощью библиотеки lift-json.В моем приложении для Android я использую Scala 2.9.0 и lift-json_2.9.0_2.4-M1.

Я взял простой пример из readme-файла lift-json, но каждый раз пытаюсь извлечь значения изJSON-String Я получаю исключение net.liftweb.json.MappingException при вызове Activity.Кажется, что нет никаких аргументов, доставленных в «extract».

Вот моя активность:

import _root_.android.app.Activity
import _root_.android.os.Bundle
import net.liftweb.json._

class JsonTest extends Activity {

  override def onCreate(savedInstanceState: Bundle) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.mainactivity)

    implicit val formats = DefaultFormats
    case class NumList(numbers: List[Int])
    val json = parse(""" { "numbers" : [1, 2, 3, 4] } """)
    json.extract[NumList]
  }
}

и вот исключение, которое я получаю:

06-29 12:09:31.548: ERROR/AndroidRuntime(405): FATAL EXCEPTION: main
    java.lang.RuntimeException: Unable to start activity ComponentInfo{de.fhs.spirit/de.fhs.spirit.JsonTest}: net.liftweb.json.MappingException: Parsed JSON values do not match with class constructor
    args=
    arg types=
    constructor=public de.fhs.spirit.JsonTest$NumList$2(de.fhs.spirit.JsonTest,scala.collection.immutable.List)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
    at android.app.ActivityThread.access$2300(ActivityThread.java:125)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    at android.os.Looper.loop(Looper.java:123)
    at android.app.ActivityThread.main(ActivityThread.java:4627)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:521)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
    at dalvik.system.NativeStart.main(Native Method)
    Caused by: net.liftweb.json.MappingException: Parsed JSON values do not match with class constructor
    args=
    arg types=
    constructor=public de.fhs.spirit.JsonTest$NumList$2(de.fhs.spirit.JsonTest,scala.collection.immutable.List)
    at net.liftweb.json.Meta$.fail(Meta.scala:185)
    at net.liftweb.json.Extraction$.instantiate$1(Extraction.scala:257)
    at net.liftweb.json.Extraction$.newInstance$1(Extraction.scala:280)
    at net.liftweb.json.Extraction$.build$1(Extraction.scala:298)
    at net.liftweb.json.Extraction$.extract0(Extraction.scala:345)
    at net.liftweb.json.Extraction$.net$liftweb$json$Extraction$$extract0(Extraction.scala:194)
    at net.liftweb.json.Extraction$.extract(Extraction.scala:42)
    at net.liftweb.json.JsonAST$JValue.extract(JsonAST.scala:290)
    at de.fhs.spirit.JsonTest.onCreate(JsonTest.scala:16)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
    ... 11 more

Было быЗдорово, если у вас есть идея, как решить мою проблему.Спасибо!

Привет, Иллаз

1 Ответ

2 голосов
/ 29 июня 2011

Я подозреваю, что Лифт использует отражение в этом режиме. Это может вообще не работать в Android, или может потребоваться удалить некоторые вещи, которые были удалены , а не . Я предлагаю вам просто попробовать использовать некоторые другие альтернативы.

См. Также этот вопрос - мое подозрение исходит из замечания, что он не работает на REPL. Не то, чтобы у REPL не было отражения, но его структура пакета может сбивать с толку библиотеку Lift.

...