Как использовать NodeJS в Android с помощью J2V8
Я создал код для Android с использованием библиотеки J2V8 для выполнения сценария nodejs в Android Mobile. но это дает мне ошибку при запуске приложения.
Gradle зависимости
compile 'com.eclipsesource.j2v8:j2v8:4.6.0@aar'
Код
...
@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
ИЛИ ЖЕ
- Поднимите заявку на их GitHub, чтобы они могли обновить AAR с обновленной нативной библиотекой с поддержкой узлов.