сбой уведомления о реактивной базе - PullRequest
0 голосов
/ 03 октября 2018

Приложение вылетает при получении уведомления на Android-устройстве с Android OS 8.1.0, в симуляторе.Это происходит в то время как в приложении.Это не происходит, когда я нахожусь за пределами приложения, и уведомление приходит нормально в трее уведомлений.Однако на реальном устройстве это происходит как внутри, так и снаружи (?).Сбой не происходит для Android 5.0.0.

Ошибка в Crashlytics:

Caused by java.lang.NoSuchMethodError: No direct method <init>(Landroid/content/Context;Ljava/lang/String;)V in class Landroid/support/v4/app/NotificationCompat$Builder; or its super classes (declaration of 'android.support.v4.app.NotificationCompat$Builder' appears in /data/app/com.parkour2342345-zqe_7U0B_6slVtK2mLk6RA==/base.apk!classes2.dex)
       at io.invertase.firebase.notifications.DisplayNotificationTask.doInBackground(DisplayNotificationTask.java:68)
       at io.invertase.firebase.notifications.DisplayNotificationTask.doInBackground(DisplayNotificationTask.java:31)
       at android.os.AsyncTask$2.call(AsyncTask.java:333)
       at java.util.concurrent.FutureTask.run(FutureTask.java:266)
       at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:245)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
       at java.lang.Thread.run(Thread.java:764)

, а также:

Fatal Exception: java.lang.RuntimeException: An error occurred while executing doInBackground()
       at android.os.AsyncTask$3.done(AsyncTask.java:353)
       at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:383)
       at java.util.concurrent.FutureTask.setException(FutureTask.java:252)
       at java.util.concurrent.FutureTask.run(FutureTask.java:271)
       at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:245)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
       at java.lang.Thread.run(Thread.java:764)

Мой build.gradle дляresponse-native-firebase содержит:

def DEFAULT_COMPILE_SDK_VERSION = 27
def DEFAULT_BUILD_TOOLS_VERSION = "27.0.3"
def DEFAULT_TARGET_SDK_VERSION = 26
def DEFAULT_FIREBASE_VERSION = "12.0.0"
def DEFAULT_SUPPORT_LIB_VERSION = "27.0.2"

android {
  compileSdkVersion rootProject.hasProperty('compileSdkVersion') ? rootProject.compileSdkVersion : DEFAULT_COMPILE_SDK_VERSION
  buildToolsVersion rootProject.hasProperty('buildToolsVersion') ? rootProject.buildToolsVersion : DEFAULT_BUILD_TOOLS_VERSION
  defaultConfig {
    minSdkVersion 16
    targetSdkVersion rootProject.hasProperty('targetSdkVersion') ? rootProject.targetSdkVersion : DEFAULT_TARGET_SDK_VERSION
    versionCode 1
    versionName "1.0"
    multiDexEnabled true
  }

Я разместил вопрос здесь: https://github.com/invertase/react-native-firebase/issues/1553

Среда

Целевая платформа приложения: Android

Операционная система разработки: macOS High Sierra 10.13.6

Инструменты сборки: Android Studio: 3.1 AI-173.4670197

React Собственная версия: 0.54.4 => 0.54.4

React Native Firebase Версия: 4.3.8

Модуль Firebase: обмен сообщениями

Используете ли вы машинопись?нет


обновление # 1:

в build.gradle реагирования-нативной навигации:

def DEFAULT_SUPPORT_LIB_VERSION = "27.0.2"
...
def supportVersion = rootProject.hasProperty('supportLibVersion') ? rootProject.supportLibVersion : DEFAULT_SUPPORT_LIB_VERSION

dependencies {
  // compile fileTree(include: ['*.jar'], dir: 'libs')
  api "com.facebook.react:react-native:+"  // From node_modules
  api "com.android.support:support-v4:$supportVersion"

там, похоже, отсутствует supportLibVersion, определенный впроект, поэтому я предполагаю, что он унаследует значение в файле.Кроме того, хотя восстановление проекта работает, оно выделяет линию красным цветом.enter image description here

1 Ответ

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

решение, после нескольких часов разочарования: 1) удаленная строка: api "com.android.support:support-v4:$supportVersion"

2) изменил sdk на 27. def DEFAULT_TARGET_SDK_VERSION = 27

по номиналу, ни один из них не должен это исправить, но они сделали ...

...