我正在研究当前的Android应用程序中的de.undercouch:citeproc-java:2.0.0
我无法使用ScriptEngine识别可在Android上使用的citeproc-java
我的 Gradle 类似于:

ext {
    compileSdkVersion = 30
    minSdkVersion = 26
    targetSdkVersion = 30
}

dependencies {

    implementation 'io.apisense:rhino-android:1.1.1'

    implementation 'de.undercouch:citeproc-java:2.0.0'
    implementation 'org.citationstyles:styles:20.11'
    implementation 'org.citationstyles:locales:20.11'

    implementation 'androidx.appcompat:appcompat:1.2.0'
    implementation 'com.google.android.material:material:1.2.1'
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:1.4.10"
}
Citeproc需要的javax.script.ScriptEngineManager在Android平台上不可用,因此我替换了io.apisense:rhino-android:1.1.1我现在正面临这个异常(exception)...
2020-11-19 10:02:22.325 4426-4426/com.google.android.gms.location.sample.basiclocationsample E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.google.android.gms.location.sample.basiclocationsample, PID: 4426
    java.lang.RuntimeException: Unable to start activity ComponentInfo{----}: java.lang.IllegalArgumentException: Could not make bibliography
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3270)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016)
        at android.os.Handler.dispatchMessage(Handler.java:107)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:7356)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)
     Caused by: java.lang.IllegalArgumentException: Could not make bibliography
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:797)
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:764)
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:750)
        at com.google.android.gms.location.sample.basiclocationsample.MainActivity.what(MainActivity.kt:86)
        at com.google.android.gms.location.sample.basiclocationsample.MainActivity.onCreate(MainActivity.kt:66)
        at android.app.Activity.performCreate(Activity.java:7802)
        at android.app.Activity.performCreate(Activity.java:7791)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1306)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3245)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409) 
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83) 
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016) 
        at android.os.Handler.dispatchMessage(Handler.java:107) 
        at android.os.Looper.loop(Looper.java:214) 
        at android.app.ActivityThread.main(ActivityThread.java:7356) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930) 
     Caused by: de.undercouch.citeproc.script.ScriptRunnerException: Could not call method
        at de.undercouch.citeproc.script.JREScriptRunner.callMethod(JREScriptRunner.java:87)
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:784)
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:764) 
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:750) 
        at com.google.android.gms.location.sample.basiclocationsample.MainActivity.what(MainActivity.kt:86) 
        at com.google.android.gms.location.sample.basiclocationsample.MainActivity.onCreate(MainActivity.kt:66) 
        at android.app.Activity.performCreate(Activity.java:7802) 
        at android.app.Activity.performCreate(Activity.java:7791) 
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1306) 
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3245) 
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409) 
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83) 
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016) 
        at android.os.Handler.dispatchMessage(Handler.java:107) 
        at android.os.Looper.loop(Looper.java:214) 
        at android.app.ActivityThread.main(ActivityThread.java:7356) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930) 
     Caused by: javax.script.ScriptException: org.mozilla.javascript.EcmaError: TypeError: Cannot read property "strings" from undefined (<Unknown source>#14312) in <Unknown source> at line number 14312
        at com.sun.script.javascript.RhinoScriptEngine.invoke(RhinoScriptEngine.java:330)
        at com.sun.script.javascript.RhinoScriptEngine.invokeMethod(RhinoScriptEngine.java:296)
        at de.undercouch.citeproc.script.JREScriptRunner.callMethod(JREScriptRunner.java:84)
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:784) 
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:764) 
        at de.undercouch.citeproc.CSL.makeBibliography(CSL.java:750) 
        at com.google.android.gms.location.sample.basiclocationsample.MainActivity.what(MainActivity.kt:86) 
        at com.google.android.gms.location.sample.basiclocationsample.MainActivity.onCreate(MainActivity.kt:66) 
        at android.app.Activity.performCreate(Activity.java:7802) 
        at android.app.Activity.performCreate(Activity.java:7791) 
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1306) 
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3245) 
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409) 
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83) 
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016) 
        at android.os.Handler.dispatchMessage(Handler.java:107) 
        at android.os.Looper.loop(Looper.java:214) 
        at android.app.ActivityThread.main(ActivityThread.java:7356) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930) 
     Caused by: org.mozilla.javascript.EcmaError: TypeError: Cannot read property "strings" from undefined (<Unknown source>#14312)
        at org.mozilla.javascript.ScriptRuntime.constructError(ScriptRuntime.java:4198)
        at org.mozilla.javascript.ScriptRuntime.constructError(ScriptRuntime.java:4176)
        at org.mozilla.javascript.ScriptRuntime.typeError(ScriptRuntime.java:4209)
        at org.mozilla.javascript.ScriptRuntime.typeError2(ScriptRuntime.java:4228)
        at org.mozilla.javascript.ScriptRuntime.undefReadError(ScriptRuntime.java:4240)
        at org.mozilla.javascript.ScriptRuntime.getObjectProp(ScriptRuntime.java:1570)
        at org.mozilla.javascript.Interpreter.interpretLoop(Interpreter.java:1336)
        at org.mozilla.javascript.Interpreter.interpret(Interpreter.java:911)
        at org.mozilla.javascript.InterpretedFunction.call(InterpretedFunction.java:109)
        at org.mozilla.javascript.ContextFactory.doTopCall(ContextFactory.java:405)
        at com.sun.script.javascript.RhinoScriptEngine$1.superDoTopCall(RhinoScriptEngine.java:146)
        at com.sun.script.javascript.RhinoScriptEngine$1.doTopCall(RhinoScriptEngine.java:139)
        at org.mozilla.javascript.ScriptRuntime.doTopCall(ScriptRuntime.java:3508)
        at org.mozilla.javascript.InterpretedFunction.call(InterpretedFunction.java:107)
2020-11-19 10:02:22.325 4426-4426/com.google.android.gms.location.sample.basiclocationsample E/AndroidRuntime:     at com.sun.script.javascript.RhinoScriptEngine.invoke(RhinoScriptEngine.java:324)
            ... 22 more
导致此异常的citeproc代码直接来自其示例...
private fun what() {

    val citeproc = CSL(MyItemProvider(), "ieee")
    citeproc.setOutputFormat("text")
    citeproc.registerCitationItems("ID-1", "ID-2", "ID-3")

    val s1 = citeproc.makeCitation("ID-1")
    println(s1[0].text)
    //=> [1] (for the "ieee" style)

    //=> [1] (for the "ieee" style)
    val s2 = citeproc.makeCitation("ID-2")
    println(s2[0].text)
    //=> [2]

    //=> [2]
    val bibl = citeproc.makeBibliography()  //EXCEPTION RAISED HERE!!!!!!
    for (entry in bibl.entries) {
        println(entry)
    }

}
我创建了一个AndroidJUnit来调查此问题。
在逐步检查代码时,我发现问题是访问字符串的arrayOutOfBoundsException []
该数组只有12个条目,但索引为39
如AS镜像所示
android - 如何在Android上使用citeproc-java-LMLPHP

最佳答案

正如我在调试器中看到的值所示,它在 iCode [] array中显示了12个项目。
并且from.pc的的值为39,这是数组索引异常的原因。
作为参数,您的 from.pc 值以一个条件增加预递增,而其他值则以post递增,每次增加2。
而且,您在使用continue时不检查总是会产生异常的数组的大小。
您应该检查条件,因为如果第39个位置的期望值或索引的增量不合适,则数组似乎可以正确初始化。

10-08 02:57