Как использовать NodeJS в Android с помощью J2V8

Я создал код для android, используя J2V8 библиотеку для выполнения nodejs script в android mobile. но это дает мне ошибку при запуске приложения.

Gradle зависимости

compile 'com.eclipsesource.j2v8:j2v8:[email protected]'

Код

...

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_console);
    runScript();
}

private void runScript() {
    NodeJS nodeJS = NodeJS.createNodeJS();

    try {
        File script = createTempScript("console.log(\"Hello NodeJS\")");

        nodeJS.exec(script);

        script.delete();
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        nodeJS.release();
    }

}

private File createTempScript(String script) throws IOException {
    File file = File.createTempFile("temp",".js", getCacheDir());
    FileWriter fileWriter = new FileWriter(file);
    fileWriter.write(script);
    fileWriter.close();
    return file;
}

...

Ошибка

java.lang.RuntimeException: Unable to start activity ComponentInfo{in.asissuthar.lion/in.asissuthar.lion.ConsoleActivity}: java.lang.UnsupportedOperationException:
StartNodeJS Not Supported.
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2348)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2410)
        at android.app.ActivityThread.access$800(ActivityThread.java:151)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1313)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:135)
        at android.app.ActivityThread.main(ActivityThread.java:5345)
        at java.lang.reflect.Method.invoke(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:372)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:947)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:742)

Пожалуйста, помогите мне решить эту ошибку.


Нормальный двигатель V8 работает нормально, но выше createNodeJS дает ошибку.

V8 v8 = V8.createV8Runtime()

Ответ 1

Корневая причина

Библиотека J2V8 содержит JAR и собственную библиотеку, содержащую движок v8. В вашем случае исходная библиотека JNI не скомпилирована с параметром -D NODE_COMPATIBLE=1, и, следовательно, вы получаете следующую ошибку:

java.lang.RuntimeException: Unable to start activity ComponentInfo{in.asissuthar.lion/in.asissuthar.lion.ConsoleActivity}: java.lang.UnsupportedOperationException: StartNodeJS Not Supported.

Это можно утверждать, просмотрев код J2V8. Я добавил ниже фрагмент:

#ifndef NODE_COMPATIBLE
  (env)->ThrowNew(unsupportedOperationExceptionCls, "StartNodeJS Not Supported.");
#endif

Возможные решения:

  • Вам необходимо перекомпилировать исходный код JNI с опцией -D NODE_COMPATIBLE=1. Исходный код доступен в https://github.com/eclipsesource/J2V8

ИЛИ

  1. Поднимите билет на свой github, чтобы они могли обновить aar с обновленной собственной библиотекой с поддержкой node.