Версии всех зависимостей Firebase одинаковы, приложение по-прежнему падает после запуска - PullRequest
2 голосов
/ 05 апреля 2019

Я заметил, что это довольно распространенный вопрос, поэтому я провел некоторое исследование и попытался решить его самостоятельно, но без каких-либо положительных результатов.Так что если у кого-то будут какие-то идеи, как решить эту проблему, я буду очень признателен.Я застрял на этом в течение нескольких часов.

Я смотрю в эти темы:

  1. Приложение зависает от базы данных Firebase - там я узнал, что явсе мои версии зависимостей должны быть одинаковыми.
  2. Сбои приложения Android - в этой теме они предложили использовать последние версии в зависимости от официального сайта google .
  3. А также здесь Я нашел те же предложения - версии должны быть одинаковыми, очистить и перестроить ваш проект и т. Д.

Что я понимаю, так это проблема: зависимостинесовместимы

ПРИМЕЧАНИЕ. Мое приложение работало нормально только с базой данных firebase-realtime.После добавления firebase-auth он мгновенно падает (тестирование на Huawei P9 lite НЕ на эмуляторе).

Что я пробовал:

1) Делаем все зависимости новейшими версиями.Это не сработало - все равно приложение вылетает сразу после запуска.

implementation 'com.google.firebase:firebase-core:16.0.8'

implementation 'com.google.firebase:firebase-database:16.1.0'

implementation 'com.google.firebase:firebase-auth:16.2.0'

2) Понижение зависимостей до ближайшей версии, которая у них всех общая, на основе этой ссылки (которая16.0.5).

implementation 'com.google.firebase:firebase-core:16.0.5'

implementation 'com.google.firebase:firebase-database:16.0.5'

implementation 'com.google.firebase:firebase-auth:16.0.5'

3) Когда я пытался добавить firebase-auth через менеджер инструментов, он вставил 'com.google.firebase:firebase-auth:16.0.3', что привело к этой ошибке:

ERROR: In project 'app' a resolved Google Play services library dependency depends on another at an exact version (e.g. "[15.0. 1]", but isn't being resolved to that version. Behavior exhibited by the library will be unknown.

Dependency failing: com.google.android.gms:play-services-flags:15.0.1 -> com.google.android.gms:play-services-basement@[
15.0.1], but play-services-basement version was 16.0.1.

The following dependencies are project dependencies that are direct or have transitive dependencies that lead to the art ifact with the issue.
-- Project 'app' depends onto com.google.firebase:firebase-core@16.0.5
-- Project 'app' depends onto com.google.firebase:firebase-iid@17.0.3
-- Project 'app' depends onto com.google.firebase:firebase-analytics@16.0.5
-- Project 'app' depends onto com.google.firebase:firebase-common@16.0.4
-- Project 'app' depends onto com.google.android.gms:play-services-stats@16.0.1
-- Project 'app' depends onto com.google.android.gms:play-services-basement@16.0.1
-- Project 'app' depends onto com.google.firebase:firebase-auth-interop@16.0.0
-- Project 'app' depends onto com.google.android.gms:play-services-flags@15.0.1
-- Project 'app' depends onto com.google.android.gms:play-services-tasks@16.0.1
-- Project 'app' depends onto com.google.firebase:firebase-measurement-connector-impl@17.0.3
-- Project 'app' depends onto com.google.android.gms:play-services-base@16.0.1
-- Project 'app' depends onto com.google.firebase:firebase-analytics-impl@16.2.3
-- Project 'app' depends onto com.google.firebase:firebase-database@16.0.5
-- Project 'app' depends onto com.google.firebase:firebase-iid-interop@16.0.1
-- Project 'app' depends onto com.google.android.gms:play-services-measurement-base@16.0.4
-- Project 'app' depends onto com.google.android.gms:play-services-ads-identifier@16.0.0
-- Project 'app' depends onto com.google.firebase:firebase-measurement-connector@17.0.1
-- Project 'app' depends onto com.google.firebase:firebase-auth@16.0.3
-- Project 'app' depends onto com.google.android.gms:play-services-measurement-api@16.0.3

Вот как выглядит файл Gradle моего уровня приложения:

apply plugin: 'com.android.application'
apply plugin: 'com.google.gms.google-services'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.example.test123"
        minSdkVersion 21
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'

    implementation 'com.android.support:animated-vector-drawable:28.0.0'
    implementation 'com.android.support:support-media-compat:28.0.0'
    implementation 'com.android.support:support-v4:28.0.0'

    implementation 'com.google.firebase:firebase-core:16.0.5'

    implementation 'com.google.firebase:firebase-database:16.0.5'

    implementation 'com.google.firebase:firebase-auth:16.0.5'

    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

apply plugin: 'com.google.gms.google-services'

Это мой файл Gradle:

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    repositories {
        google()
        jcenter()
    }
    dependencies {

        // Android Gradle Plugin
        classpath 'com.android.tools.build:gradle:3.3.2'

        // Google Services Plugin
        classpath "com.google.gms:google-services:4.2.0"

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()

    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

И, наконец, мой logcat:

04-05 14:04:36.000 906-906/? I/art: Late-enabling -Xcheck:jni
04-05 14:04:36.192 906-906/com.example.test123 W/System: ClassLoader referenced unknown path: /data/app/com.example.test123-1/lib/arm64
04-05 14:04:36.439 906-922/com.example.test123 I/art: Background partial concurrent mark sweep GC freed 11193(638KB) AllocSpace objects, 4(80KB) LOS objects, 21% free, 15MB/19MB, paused 343us total 105.488ms at HeapTaskDaemon thread CareAboutPauseTimes 1
04-05 14:04:36.658 906-957/com.example.test123 W/DynamiteModule: Local module descriptor class for com.google.firebase.auth not found.
04-05 14:04:36.686 906-956/com.example.test123 I/FA: App measurement is starting up, version: 14700
04-05 14:04:36.686 906-956/com.example.test123 I/FA: To enable debug logging run: adb shell setprop log.tag.FA VERBOSE
04-05 14:04:36.686 906-956/com.example.test123 I/FA: To enable faster debug mode event logging run:
      adb shell setprop debug.firebase.analytics.app com.example.test123
04-05 14:04:36.717 906-906/com.example.test123 I/FirebaseInitProvider: FirebaseApp initialization successful
04-05 14:04:36.723 906-961/com.example.test123 W/DynamiteModule: Local module descriptor class for com.google.firebase.auth not found.
04-05 14:04:36.733 906-961/com.example.test123 I/FirebaseAuth: [FirebaseAuth:] Loading module via FirebaseOptions.
04-05 14:04:36.733 906-961/com.example.test123 I/FirebaseAuth: [FirebaseAuth:] Preparing to create service connection to gms implementation
04-05 14:04:37.017 906-976/com.example.test123 I/System: core_booster, getBoosterConfig = false
04-05 14:04:37.048 906-906/com.example.test123 I/HwCust: Constructor found for class android.app.HwCustHwWallpaperManagerImpl
04-05 14:04:37.254 906-906/com.example.test123 W/art: Before Android 4.1, method android.graphics.PorterDuffColorFilter android.support.graphics.drawable.VectorDrawableCompat.updateTintFilter(android.graphics.PorterDuffColorFilter, android.content.res.ColorStateList, android.graphics.PorterDuff$Mode) would have incorrectly overridden the package-private method in android.graphics.drawable.Drawable
04-05 14:04:37.673 906-906/com.example.test123 I/art: Rejecting re-init on previously-failed class java.lang.Class<android.support.v4.view.ViewCompat$OnUnhandledKeyEventListenerWrapper>
04-05 14:04:37.674 906-906/com.example.test123 I/art: Rejecting re-init on previously-failed class java.lang.Class<android.support.v4.view.ViewCompat$OnUnhandledKeyEventListenerWrapper>
04-05 14:04:38.485 906-906/com.example.test123 I/Process: Sending signal. PID: 906 SIG: 9

Ответы [ 4 ]

1 голос
/ 05 апреля 2019

Возможно, проблема в вашем устройстве, возможно, службы Google Play не обновлены для поддержки версии, запрашиваемой вашим приложением.

Попробуйте обновить сервисы Google Play на своем устройстве или перейдите на другое устройство и протестируйте его там.

0 голосов
/ 05 апреля 2019

Когда мы используем несколько библиотек, некоторые из которых уже включены в некоторые библиотеки, но с другой версией no, мы сталкиваемся с такими проблемами.Для этого вы можете заставить ваш gradle везде использовать одну версию библиотеки

configurations.all {
 resolutionStrategy {
   force "com.google.firebase:firebase-core:${VERSION_XYZ}”
   force "com.google.firebase:firebase-database:${VERSION_ABC}”
 }}
 dependencies {
   // ... all dependencies here...
 }

Таким образом, сделайте это для каждой библиотеки и определите ее в файле gradle, это может помочь вам.

0 голосов
/ 05 апреля 2019

Попробуйте, это сработает для вас. Удачного кодирования:)

implementation 'com.google.firebase:firebase-core:16.0.8'
implementation 'com.google.firebase:firebase-database:16.1.0'
implementation 'com.google.firebase:firebase-auth:16.2.0'
0 голосов
/ 05 апреля 2019

Попробуйте, это может сработать.

implementation 'com.google.firebase:firebase-core:16.0.1'
implementation 'com.google.firebase:firebase-database:16.0.1'
implementation 'com.google.firebase:firebase-auth:16.0.1'
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...