react-native报错锦集

下面是一些rn问题的分类:

1.rn的版本问题,如0.55.6版本就是这样的,安装的时候就会报错,
2.link组件的问题,有些时候会发生自动link不全或者路径错误的情况,
3.安卓版本问题,组件的版本和rn项目版本统一
4.其他问题,

其实我建议还是学一下android原生,包括gradle,不然后面涉及太多原生问题很难解决。

1.rn版本问题

rn版本更新的很快,有些版本说实话根本用不了,比如0.55.6,都启动不了,
我推荐几个我用过的版本,** 0.55.4 , 0.57.0**。 这两个相对来说还算稳定。

2.react-native link xxx 问题

link的时候很多时候会出现不全的问题,这也是很多人害怕的问题,尤其一开始做这个项目的时候,项目写的好好的一link就出错,网上半天找不到解决方案。其实主要把link这三个地方注意些全就基本没问题了。以react-native-baidu-map组件为例

  1. android/settings.gradle里面
    rootProject.name = 'apps'
    include ':react-native-baidu-map'
    project(':react-native-baidu-map').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-baidu-map/android');
    include ':app';
  1. android/app/build.gradle里面
dependencies {
    implementation project(':react-native-baidu-map')
}
  1. android/app/src/main/java/../MainApplication.java
@Override
protected List<ReactPackage> getPackages() {
    return Arrays.<ReactPackage>asList(
        new MainReactPackage(),
        new BaiduMapPackage(getApplicationContext()),
    );
}

3.android版本问题

这是个大问题,我现在用的androidsdk28的,rn一开始建议的是23,其实这个已经是很老的版本的,很多组件都是在新版本上构建的
如果组件里面的版本大多不统一,那么最好就全部改成最高的版本,android向下兼容一般改成高版本没什么大问题,
有一个经常遇到的一个语法问题,在link的时候低版本 implementation要改成compile,

dependencies {
    implementation project(':react-native-baidu-map')
}

4.其他问题

其他问题么就不多说了,各种各样的都有,

接下来就说下其他的报错案例

  1. Execution failed for task ':app:installDebug'.com.android.builder.testing.api.DeviceException: com.android.ddmlib.InstallException: device '860BDMP22B63' not found
    解决方法: adb reverse tcp:8081 tcp:8081 关闭usb调试再重新打开

  1. 初始化运行红屏错误 unable to load script from asset/index.android.bundle
    assets中没有成功打包出index.android.bundle文件
    解决方法: 1.去(你的项目文件夹)\android\app\src\main目录下新建asset文件夹
         2.终端下运行
         react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res
    此命令运行不成功把"babel-preset-react-native": "^2.1.0",
    的配置改一下
    再次执行 react-native run-android
      注:由于0.49版本以后的react-native没有index.android.js和index.ios.js文件,而统一合并成了index.js,所以使用0.49及以后版本的同学请将第2步中的入口文件改为index.js

  1. the development server trturned response error code:500
    解决方法: 删除node包重新install,要用npm不能用cnpm

4.bundlin failed: error:unable to resolve module 'AccessibilityInfo' form '...node_modules/...react-native-implementation.js':Module' AccessibilityInfo does not exist in the Hast..
解决方法: 这个是0.56的版本问题,换成0.55.4版本就行了


  1. 运行断开,有时候会出现运行成功了但是又断开了,直接新运行就好了

  1. 使用AsyncStorage debug不出来数据,也就是本地存储失效了,需要取消debug模式,这和react-native运行模式有关

  1. Error(1,0) Your project path contains non-ASCII characters,This will most likely cause the
    build to fail on Windows,

    解决方法: 项目不能有中文路径

  1. 引用react-native-camera保存问题,rn0.55.4版本
    解决问题的地址: git连接

  1. com.android.builder.testing.api.DeviceException:com.android.ddmlib.InstallException:Failed to finalize pession:INSTALL_FAILED_UPDATE_INCOMPATIBLE: Package com.app signatures do not match the prevously installed version:ignoring!
    解决方法: 创建项目名的时候不能重名,就算之前删除了,除非彻底关闭所有的相关运行程序,还有一中情况是安装了打包后的app没有卸载,在运行项目就不行

  1. react-native-baidu-map插件用法
    下载后, 高级版本不支持从 react中直接引入proptype需要改成
import PropTypes from 'prop-types';

把所有react-native-baidu-map里面的js文件都改掉,同时其android/src/main/java/org/lovebing/reactnative/baidumap/BiduMapPackage.java里面注释掉@Override如果还有问题,就找到BaiduMapViewManager.java 文件,注释掉里面含public boolean的@Override


  1. 重要一点,开发时候需要用到安卓的debug.keystore的密钥库的SHA1密码来生成百度地图的key,不然测试的百度地图一直时网格状,

项目的包名必须与key申请的包名一致
注意,只有在 .android 目录下生产的秘钥签名才是百度地图生产key所需要的秘钥
而不是打包的时候在java jdk目录下生产的秘钥

react-native-camera 集成
按照网上配置好集成环境,然后再按照
https://github.com/react-native-community/react-native-camera/issues/1530
文件修改下配置,
最后只能用RNCamera, 不能用Camera组件


  1. a problem occourred evaluating project: 'react-native-fast-image'
    Could not find method implementation() for arguments[com.facebook.react:react-native:+]

    解决办法: 把node_module下的fast-image里面的compile修改成implementation,高版本的gradle语法变了,

  1. 低版本rn有长屏幕手机撑不开的问题
    cleartext communication to localhost not permitted by network security policy
    ,需要加
<meta-data android:name="android.max_aspect" android:value="2.2"/>

  1. 高版本手机请求不到数据,因为高版本8.0以上手机默认支持https请求,
    解决办法: 在AndroidManifest.xml文件里面 application下添加android:usesCleartextTraffic="true"

  1. **./gradlew assembleRelease的时候的错误
  • What went wrong:
    Execution failed for task ':app:generateReleaseBuildConfig'.

java.nio.file.DirectoryNotEmptyException: D:\work\2018\08-03\water\App\apps\android\app\build\generated\source\buildConfig\release\com

  • Try:
    Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.

BUILD FAILED in 2s
11 actionable tasks: 1 executed, 10 up-to-date**

要重新清理下文件, ./gradlew clean


  1. 调用的百度地图一直是网格状,显示不出来
    这里需要注意这几个点
  • 1:调试的时候只能用 debug.keystore,
  • 2:正式打包需要用 在./android 目录下的(一般是在c盘的appdada里面)生成的keystore才行,而不是在java sdk目录下生成的keystore,这两个有区别。

  1. **A problem occurred evaluating project ':react-native-file-selector'.

Could not find method google() for arguments [] on repository container.**

解决办法: gradle-wrapper.properties 里面的distributionUrl = https://services.gradle.org/distributions/gradle-4.1-all.zip


  1. **Execution failed for task ':app:preDebugBuild'.

Android dependency 'com.android.support:support-fragment' has different version for the compile (26.1.0) and runtime (27.1.1) classpath. You should manually set the same version via DependencyResolution**

解决办法: 我所用的没有support-fragment这个依赖,所以应该是build冲突,清除build文件,./gradlew clean后就好了


  1. > Task :react-native-fast-image:compileDebugJavaWithJavac
    注: [2] Wrote GeneratedAppGlideModule with: [com.bumptech.glide.integration.okhttp3.OkHttpLibraryGlideModule, com.dylanvann.fastimage.FastImageOkHttpProgressGlideModule]

解决办法删了他吧react-native-fast-image ,换个版本吧,最新版本有问题啊,我之前用的5.1.0


  1. 打包的时候可能出现的问题 node_modules_reactnavigation_src_views_assets_backicon.png, but the error uncompiled PNG file passed as argument. Must be compiled first into .flat file.. error: failed parsing overlays.
    在gradle.properties文件中添加以下行:android.enableAapt2 = false,让他使用旧的aapt方式来获取资源打包,虽然不推荐,我用的是0.57.0的版本,一开始打包是没有这个问题的,不知道后面改了android哪里的资源导致的,因为改的东西太多了,没办法。我建议还是升级下app版本,把项目移植过去,以免后面继续出现其他问题。

  1. Exception in thread "main" javax.net.ssl.SSLException: Connection has been shutdown: javax.net.ssl.SSLException: SSL peer shut down incorrectly

网的问题,下载不到distributionUrl=https://services.gradle.org/distributions/gradle-4.10.2-all.zip文件,可以陪下镜像阿里云

buildscript {
    repositories {
        google()
        maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
        jcenter()
    }
}

allprojects {
    repositories {
        mavenLocal()
        google()
        maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
        jcenter()
        maven {
            url "$rootDir/../node_modules/react-native/android"
        }
    }
}

配置了这个也没有,翻墙也下载不下来的话去官网下载吧,
gradle地址


  1. Error: Unable to resolve module ./index from \node_modules\react-native\scripts/.: The module ./index could not be found from \node_modules\react-native\scripts/.. Indeed, none of these files exist:
    解决方法: 这个是用了0.59.0-0.59.2版本的问题,换成0.59.4就可以了

  1. Error: null, Cannot fit requested classes in a single dex file (# methods: 71853 > 65536)
    这个是由于android 的64K 引用限制,具体参照原文
    在gradle里面添加multiDexEnabled true 就行了
android {
    defaultConfig {
        ...
        minSdkVersion 21
        targetSdkVersion 28
        multiDexEnabled true
    }
    ...
}

dependencies {
  implementation 'com.android.support:multidex:1.0.3'
}

添加这个后项目高版本手机可以运行了,但是低版本的android就会crash,起都起不来,会报错主类加载不到。我用到的是4.4.4版本的手机,文档写的是android5.0之前的手机不行。然后解决办法是, 主类继承MultiDexApplication ,而不是继承Application类,文档里面还写了引用的时候换成android:name="android.support.multidex.MultiDexApplication" ,但是换了后却是无法使用,所有我这里没换,是可以使用的;还有问题可以参照连接,仔细看下。


  1. android 底版本沉浸栏不起效
    解决办法: 正常安装rn官网的沉浸栏设置,高版本是可以实现沉浸栏的,但是我的测试手机4.4版本不行,沉浸栏还是原来的,需要在 android/app/src/main/res/styles.xml 里面的
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">

里面添加

<item name="android:windowTranslucentStatus">true</item>

  1. **Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'.

com.android.builder.dexing.DexArchiveMergerException: Error while merging dex archives:
The number of method references in a .dex file cannot exceed 64K.
Learn how to resolve this issue at https://developer.android.com/tools/building/multidex.html**

这个问题是android引用第三方库方法超过了64k大小的限制,
解决办法: 在build.gradle的 defaultConfig里面添加 multiDexEnabled true 设置下就行了,
但是设置后又会出现低版本不兼容的情况,我的是4.4.4版本的android,问题如下


  1. Process: com.socket0594, PID: 27759
    java.lang.RuntimeException: Unable to get provider android.support.v4.content.FileProvider: java.lang.ClassNotFoundException: Didn't find class "android.support.v4.content.FileProvider" on path: DexPathList[[zip file "/mnt/asec/com.socket0594-2/pkg.apk"],nativeLibraryDirectories=[/mnt/asec/com.socket0594-2/lib, /vendor/lib, /system/lib, /data/datalib]]

    这里需要android的support.v4 库来做兼容,support.v4库一般rn都引入了没有引入的这样引入下
// \android\app\build.gradle
implementation 'com.android.support:support-v4:28.0.0'

然后在 main/java/xxx 目录下的 MainApplication.java 里面修改MainApplication的继承类

import android.support.multidex.MultiDexApplication;

public class MainApplication extends MultiDexApplication implements ReactApplication {
    ...
}
// 之前是这样的
//public class MainApplication extends Application implements ReactApplication {
    //...
// }

27.rn使用StatusBar无效,正常来说不会无效的,我按照其他的的方法设置了

//在 android\app\src\main\res\values\styles.xml 里面
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
       <!-- <item name="android:windowTranslucentStatus">true</item> -->
  </style>  

这个的意思其实是设置沉浸栏的状态,是否是半透明的,设置了这个windowTranslucentStatus就会导致StatusBar无效,网上的其他人的方法谨慎参考啊

  1. 安装react-native-image-crop-picker 插件的时候Could not find com.github.yalantis:ucrop:2.2.1-native,因为缺少maven源,
    解决方法:/android/build.gradle 下
allprojects {
    repositories {
        mavenLocal()
        google()
        jcenter()
        maven {
            // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
            url "$rootDir/../node_modules/react-native/android"
        }
        maven{
            url "https://jitpack.io"
        }
        maven{
            url 'https://maven.google.com/'
            name 'Google'
        }
    }
}

29 skipping devices 'hc70' for 'app"debug' :unkonwn api level
可以先撤销usb调试,在重新连接usb,
还不行需要把允许未知的app应用安装开启,还有usb应用安装功能打开


  1. could not read path "xx\xx\app\build\intermdiate\xx\xxx"
    如果无法读取app\build里面的文件,是build的时候出现了冲突,需要进入android文件夹下面清除下build文件
    gradle clean 或者 ./gradlew clean

  1. skipping device '' for 'app:debug': could not find build of variant which supports density -1 and an abi in
    这个问题在网上没有找到解决方法,然后我就跑了原生run了一次,原生出现了问题 device supports ,but apk only supports x86, 这里是因为为了减小打包体积我设置了下so库架构
defaultConfig{
  ndk{ "x86","armeabi-v7a"}
}

可以查一下手机的cpu型号,然后根据型号选择ndk库,或者这里取消限制,注释掉,
这里改好后就在as上面起来了,然后又去react-native run-android就没有一开始的错误了。
关于so库的文章可以看这篇
so库详情


32 ** 关于阿里源的配置**
很多时候我们会遇到下载不下来jar包的情况,这时候要看清是哪个jar包下不下来,
比如这个报错 could not get 'https://jcenter.bintray.com/org/apache/...';
这个 jcenter 是国外的地址下载不到,可以配置下阿里源对应的maven 的jcenter仓库

buildscript {
    repositories {
        maven {
            url "https://maven.aliyun.com/repository/jcenter"
        }
        google()
        jcenter()
    }
}

allprojects {
    repositories {
        maven {
            url "https://maven.aliyun.com/repository/jcenter"
        }
        google()
        jcenter()
    }
}

其他源同理
阿里源maven仓库地址

  1. 错误:找不到符号, import androidx.annotation.Nullable;
    升级项目到androidx
    在 gradle.properties里面添加
android.useAndroidX=true
android.enableJetifier=true

在gradle里面添加

 implementation 'androidx.annotation:annotation:+'

重新build,如果as没有自动把项目 android.support.annotation.NonNull 替换成 androidx.annotation.NonNull 手动替换下,在build就可以了
其他地市android.support.xxx 都需要换成androidx的,
个人博客地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352