因为React Native 0.61版本以上是不需要手动link的,因此我就将原本项目里的需要link的组件使用命令
react-native unlink xxx
解绑,运行项目发现报错
Process: com.rnkey, PID: 2014
java.lang.RuntimeException: Unable to get provider com.rnkey.RNKeyFileProvider: java.lang.ClassNotFoundException: Didn't find class "com.rnkey.RNKeyFileProvider" on path: DexPathList[[zip file "/data/app/com.rnkey-2/base.apk"],nativeLibraryDirectories=[/data/app/com.rnkey-2/lib/x86, /data/app/com.rnkey-2/base.apk!/lib/x86, /vendor/lib, /system/lib]]
at android.app.ActivityThread.installProvider(ActivityThread.java:5278)
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4836)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4760)
at android.app.ActivityThread.-wrap1(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1414)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5539)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:745)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:635)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.rnkey.RNKeyFileProvider" on path: DexPathList[[zip file "/data/app/com.rnkey-2/base.apk"],nativeLibraryDirectories=[/data/app/com.rnkey-2/lib/x86, /data/app/com.rnkey-2/base.apk!/lib/x86, /vendor/lib, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at android.app.ActivityThread.installProvider(ActivityThread.java:5263)
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4836)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4760)
at android.app.ActivityThread.-wrap1(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1414)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5539)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:745)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:635)
Suppressed: java.lang.ClassNotFoundException: com.rnkey.RNKeyFileProvider
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 12 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available
错误信息一大堆,其实也就是说RNKeyFileProvider找不到,还扯了DexPathList、nativeLibraryDirectories,搞得好像很底层的样子。
其实只需要在VScode中(react native开发是用这个的工具的)搜索RNKeyFileProvider,结果果然在AndroidManifest.xml中找到它
然后编译运行应该就不会有错,如果仍然还报这个错,就将build文件夹、app/build文件夹删除,重新编译就不会报错了。如果还仍然报这个错,就将.idea文件夹删除,再重新编译运行,应该就不会再错了。