android - 火力地堡安卓 : App crash when receiving Notification after adding Invites

标签 android firebase react-native

我正在使用 React Native 构建一个使用 Firebase 消息传递、邀请等的应用程序。在我向应用程序添加 Firebase 邀请/链接之前,该应用程序运行良好。现在;即使应用程序可以构建和运行,它也会在收到推送通知时崩溃。 logcat 显示:

FATAL EXCEPTION: Firebase-RNFirebaseMessagingService
09-06 15:59:43.724 19077 19566 E AndroidRuntime: Process: com.myapp, PID: 19077
09-06 15:59:43.724 19077 19566 E AndroidRuntime: java.lang.NoSuchFieldError: No static field zzadc of type [Ljava/lang/String; in class Lcom/google/android/gms/measurement/AppMeasurement$UserProperty; or its superclasses (declaration of 'com.google.android.gms.measurement.AppMeasurement$UserProperty' appears in /data/app/com.myapp-1/base.apk)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.firebase.analytics.connector.internal.zzb.<clinit>(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.firebase.analytics.connector.AnalyticsConnectorImpl.logEvent(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.firebase.messaging.zzb.zzc(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.firebase.messaging.zzb.zze(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.firebase.messaging.FirebaseMessagingService.zzd(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.firebase.iid.zzc.run(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at com.google.android.gms.common.util.concurrent.zza.run(Unknown Source)
09-06 15:59:43.724 19077 19566 E AndroidRuntime:    at java.lang.Thread.run(Thread.java:818)

我认为这是由于方法数量超过了 65k 限制并且使用了 multiDex 和 proguard 但结果似乎是一样的。由于堆栈跟踪显示分析;我也试过包括 Firebase Analytics,但也没有用。下面是我的 build.gradle:

apply plugin: "com.android.application"

import com.android.build.OutputFile

project.ext.react = [
    entryFile: "index.js"
]

apply from: "../../node_modules/react-native/react.gradle"

def enableProguardInReleaseBuilds = true

android {
    compileSdkVersion 26
    buildToolsVersion "26.0.1"

    defaultConfig {
        applicationId "com.myapp"
        minSdkVersion 16
        targetSdkVersion 22
        versionCode 1
        versionName "1.0"
        multiDexEnabled true
        ndk {
            abiFilters "armeabi-v7a", "x86"
        }
    }
    splits {
        abi {
            reset()
            enable enableSeparateBuildPerCPUArchitecture
            universalApk false  // If true, also generate a universal APK
            include "armeabi-v7a", "x86"
        }
    }
    signingConfigs {
        release {
            if (project.hasProperty('MYAPP_RELEASE_STORE_FILE')) {
                storeFile file(MYAPP_RELEASE_STORE_FILE)
                storePassword MYAPP_RELEASE_STORE_PASSWORD
                keyAlias MYAPP_RELEASE_KEY_ALIAS
                keyPassword MYAPP_RELEASE_KEY_PASSWORD
            }
        }
    }
    buildTypes {
        release {
            minifyEnabled enableProguardInReleaseBuilds
            proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
            signingConfig signingConfigs.release
        }
        debug {
          minifyEnabled true
          proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
        }
    }
    // applicationVariants are e.g. debug, release
    applicationVariants.all { variant ->
        variant.outputs.each { output ->
            // For each separate APK per architecture, set a unique version code as described here:
            // http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits
            def versionCodes = ["armeabi-v7a":1, "x86":2]
            def abi = output.getFilter(OutputFile.ABI)
            if (abi != null) {  // null for the universal-debug, universal-release variants
                output.versionCodeOverride =
                        versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
            }
        }
    }
}

dependencies {
    implementation project(':react-native-firebase')
    //For Firebase
    implementation "com.google.android.gms:play-services-base:15.0.1"
    implementation "com.google.firebase:firebase-core:16.0.0"
    implementation "com.google.firebase:firebase-auth:16.0.2"
    implementation "com.google.firebase:firebase-messaging:17.1.0"
    implementation "com.google.firebase:firebase-functions:16.0.1"
    implementation "com.google.firebase:firebase-invites:16.0.1"

    implementation project(':realm')
    implementation project(':react-native-pdf')
    implementation project(':react-native-fetch-blob')
    implementation (project(':react-native-camera')) {
        exclude group: "com.android.support"
    }
    implementation project(':react-native-image-picker')
    implementation project(':react-native-localization')
    implementation project(':react-native-fbsdk')
    implementation project(':react-native-linear-gradient')
    implementation fileTree(dir: "libs", include: ["*.jar"])
    implementation "com.android.support:appcompat-v7:23.0.1"
    implementation "com.facebook.react:react-native:+"  // From node_modules    

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

// Run this once to be able to run the application with BUCK
// puts all compile dependencies into folder libs for BUCK to use
task copyDownloadableDepsToLibs(type: Copy) {
    from configurations.compile
    into 'libs'
}

apply plugin: 'com.google.gms.google-services'
com.google.gms.googleservices.GoogleServicesPlugin.config.disableVersionCheck = true

在这一点上,我真的不知道该如何处理了。有人有这个问题或想法吗?

最佳答案

添加为答案: 来 self 的一个正在运行的项目,

 // Firebase dependencies 
implementation 'com.google.firebase:firebase-invites:16.0.1' 
implementation "com.google.android.gms:play-services-base:15.0.1" 
implementation "com.google.android.gms:play-services-auth:16.0.0" 
implementation "com.google.firebase:firebase-core:16.0.1" 
implementation "com.google.firebase:firebase-auth:16.0.3" 
implementation "com.google.firebase:firebase-firestore:17.1.0" 
implementation "com.google.firebase:firebase-messaging:17.3.0"

关于android - 火力地堡安卓 : App crash when receiving Notification after adding Invites,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52199761/

相关文章:

安卓 : Failed writing handshake bytes (-1 of 14): Broken pipe

Android RadioButton显示

安卓降级问题

swift - Firebase Auth lastSignInDate 和 creationDate 比较失败

javascript - Node.js Firestore 身份验证问题(当 javascript 工作时)

android - 错误: Please fix the version conflict

android - 如何引用使用 Intent/startService 创建的对象

javascript - React Native - 在 Javascript Promise 中显示加载屏幕组件

android - 在 native react 中,按钮文本未垂直居中对齐

android - 无法确定任务 ':app:lintVitalRelease' 的依赖关系