2016-12-16 71 views
0

我们正在试图整合反应本土到我们现有的Android应用程序: 我们的build.gradle的SDK要求是:集成中的反应本土到现有的应用程序

minSdkVersion 16 
targetSdkVersion 23 

我们使用一个Intent调用初始反应index.js:

Intent inte = new Intent(this, ReactNativeStarter.class); 
startActivity(inte); 

的代码的其余部分是从反应积分教程。

当我们试图拨打我们的反应成分,我们得到以下错误:

12-16 09:37:52.041 E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #4 
Process: XXXXX, PID: XXXX 
java.lang.RuntimeException: An error occured while executing doInBackground() 
    at android.os.AsyncTask$3.done(AsyncTask.java:300) 
    at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355) 
    at java.util.concurrent.FutureTask.setException(FutureTask.java:222) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:242) 
    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
    at java.lang.Thread.run(Thread.java:818) 
Caused by: java.lang.UnsatisfiedLinkError: dlopen failed: could not load library "libfbjni.so" needed by "libreactnativejni.so"; caused by cannot locate symbol "_ZSt16__get_once_mutexv" referenced by "libfbjni.so"... 
    at java.lang.Runtime.load(Runtime.java:331) 
    at java.lang.System.load(System.java:982) 
    at com.facebook.soloader.DirectorySoSource.loadLibrary(DirectorySoSource.java:63) 
    at com.facebook.soloader.SoLoader.loadLibraryBySoName(SoLoader.java:209) 
    at com.facebook.soloader.SoLoader.loadLibrary(SoLoader.java:178) 
    at com.facebook.react.bridge.JSCJavaScriptExecutor.<clinit>(JSCJavaScriptExecutor.java:25) 
    at com.facebook.react.bridge.JSCJavaScriptExecutor$Factory.create(JSCJavaScriptExecutor.java:20) 
    at com.facebook.react.ReactInstanceManagerImpl$ReactContextInitAsyncTask.doInBackground(ReactInstanceManagerImpl.java:183) 
    at com.facebook.react.ReactInstanceManagerImpl$ReactContextInitAsyncTask.doInBackground(ReactInstanceManagerImpl.java:169) 
    at android.os.AsyncTask$2.call(AsyncTask.java:288) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)  
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)  
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)  
    at java.lang.Thread.run(Thread.java:818)  

你能帮忙吗?

+0

解决该问题是通过更改excludeOptions首先在packagingOptions中解决。因为我们有一个新的反应原生错误: 由:java.lang.IllegalAccessError引起:方法'无效android.support.v4.net.ConnectivityManagerCompat。 ()'无法访问类com.facebook.react.modules.netinfo.NetInfoModule' ('com.facebook.react.modules.netinfo.NetInfoModule'的声明出现在/ data/data/at中。 ???/files/instant-run/dex/slice-com.facebook.react-react-native-0.20.1_3762d580ab3ced1fa2f7503493d38e666994b9fa-classes.dex) – NeETsu

+0

你解决了那个错误吗? – swalkner

+0

你好 是的。该问题已通过添加pickFirst instad的Exclude for the library来解决 – NeETsu

回答

0

该问题通过更改排除pick.first build.gradle

+0

您可以更清楚地了解一些build.gradle示例吗? – StevenTB

相关问题