В настоящее время мы используем флаттер для разработки приложения, которое получает 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
}