Firebase Messaging Error (только для Android) - фатальное исключение при новом Push-уведомлении - PullRequest
0 голосов
/ 08 октября 2018

В настоящее время мы используем флаттер для разработки приложения, которое получает push-уведомления.Все работало нормально, пока мы не выполнили последнее обновление Flutter, и теперь мы получаем Fatal Exception в Firebase - FlutterFirebaseMessagingService только для Android.

Я не смог найти что-либо об этом на флаттер-гите, так что это может быть проблема с Android.

Это происходит в тот момент, когда приложение получает новое уведомление с использованием функций Firebase и Firebase Messaging.Примеры данных, которые мы используем:

{
  notification: {
        title: „hello",
        body: „You got a new Message"
    },
    data: {
        click_action: "FLUTTER_NOTIFICATION_CLICK",
        additional: additional, // some integer values
        message: messageText // Same as message body above
    },
    apns: {
        payload: {
            aps: {
                badge: count,
            },
        },
    },
    token: deviceToken //this is a correct device id
}


admin.messaging().send(message)

Полный журнал устройства

E / AndroidRuntime (3436): ИСКЛЮЧИТЕЛЬНОЕ ИСКЛЮЧЕНИЕ: Firebase-FlutterFirebaseMessagingService E / AndroidRuntime (3436): Процесс: де.mandarinmedien.jutta, PID: 3436 E / AndroidRuntime (3436): java.lang.NoSuchMethodError: Нет статического метода zzc (Landroid / content / Context;) Lcom / google / firebase / iid / zzz;в классе Lcom / google / firebase / iid / zzz;или его суперклассы (объявление 'com.google.firebase.iid.zzz' появляется в /data/app/de.mandarinmedien.jutta-gn2RX8mWXXycpVEEEZIaNQ==/base.apk:classes3.dex) E / AndroidRuntime (3436):на com.google.firebase.messaging.FirebaseMessagingService.zzd (неизвестный источник: 110) E / AndroidRuntime (3436): на com.google.firebase.iid.zzg.run (неизвестный источник: 4) E / AndroidRuntime (3436):в java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1162) E / AndroidRuntime (3436): в java.util.concurrent.ThreadPoolExecutor $ Worker.run (ThreadPoolExecutor.java:636) E / Android: E36R: Android:на com.google.android.gms.common.util.concurrent.zza.run (неизвестный источник: 6) E / AndroidRuntime (3436): на java.lang.Thread.run (Thread.java:764)

Кто-нибудь уже сталкивался с этой ошибкой или знает, как ее решить?

Редактировать: android / app / build.gradle:

def localProperties = new Properties()
def localPropertiesFile = rootProject.file('local.properties')
if (localPropertiesFile.exists()) {
    localPropertiesFile.withReader('UTF-8') { reader ->
        localProperties.load(reader)
    }
}

def flutterRoot = localProperties.getProperty('flutter.sdk')
if (flutterRoot == null) {
    throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.")
}

apply plugin: 'com.android.application'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"

def keystorePropertiesFile = rootProject.file("key.properties")
def keystoreProperties = new Properties()
keystoreProperties.load(new FileInputStream(keystorePropertiesFile))

android {
    compileSdkVersion 27

    lintOptions {
        disable 'InvalidPackage'
    }

    defaultConfig {
        applicationId ******
        minSdkVersion 16
        targetSdkVersion 27
        versionCode 1
        versionName "0.1"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        multiDexEnabled true
    }

    signingConfigs {
        release {
            keyAlias keystoreProperties['keyAlias']
            keyPassword keystoreProperties['keyPassword']
            storeFile file(keystoreProperties['storeFile'])
            storePassword keystoreProperties['storePassword']
        }
    }
    buildTypes {
        release {
            signingConfig signingConfigs.debug
            minifyEnabled true
            useProguard true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

        }
    }
}

flutter {
    source '../..'
}

dependencies {
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.1'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
    implementation 'com.google.firebase:firebase-perf:16.0.0'
}

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

android / build.gradle

buildscript {
    repositories {
        google()
        jcenter()
    }

    dependencies {
        classpath 'com.android.tools.build:gradle:3.0.1'
        classpath 'com.google.gms:google-services:3.2.1'
        classpath 'com.google.firebase:firebase-plugins:1.1.5'
    }
}

allprojects {
    repositories {
        google()
        jcenter()
    }
}

rootProject.buildDir = '../build'
subprojects {
    project.buildDir = "${rootProject.buildDir}/${project.name}"
}
subprojects {
    project.evaluationDependsOn(':app')
    project.configurations.all {
        resolutionStrategy.eachDependency { details ->
            if (details.requested.group == 'com.android.support'
                    && !details.requested.name.contains('multidex')) {
                details.useVersion "27.1.1"
            }
        }
    }

}

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

1 Ответ

0 голосов
/ 09 октября 2018

сообщение об ошибке намекает на iid;служба идентификации экземпляра.это может быть предоставлено firebase-core;в то время как это также могут быть несовместимые версии, что иногда приводит к неизвестным методам и полям.

попробуйте обновить:

classpath 'com.android.tools.build:gradle:3.0.1'
classpath 'com.google.gms:google-services:3.2.1'

до текущих версий:

classpath 'com.android.tools.build:gradle:3.2.0'
classpath 'com.google.gms:google-services:4.1.0'

плагин firebase-perf должен быть вверху, а не внизу:

apply plugin: 'com.android.application'
apply plugin: 'com.google.firebase.firebase-perf'

и библиотека устарела (возможно, может потребоваться firebase-core):

implementation 'com.google.firebase:firebase-core:16.0.4'
implementation 'com.google.firebase:firebase-perf:16.1.2'

, пока ядействительно удивительно, почему нет никакой зависимости для FCM (как и следовало ожидать):

implementation 'com.google.firebase:firebase-messaging:17.3.3'

после нацеливания на уровень API 28, также предлагается настроить канал уведомлений:

<meta-data
    android:name="com.google.firebase.messaging.default_notification_channel_id"
    android:value="@string/default_notification_channel_id" />

... в настоящее время библиотеки поддержки будут иметь версию 28.0.0.

примечание: неверный синтаксис JSON может (скорее всего) возникнуть из-за неправильной публикации - в противном случае другие платформы также не будут работать;Я только добавил объяснение, что с ним не так, и удалил жестко закодированные значения.трассировка стека рассказывает совсем другую историю, не намекая на какой-либо неверный синтаксис.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...