Сбой приложения при получении уведомления - PullRequest
3 голосов
/ 13 апреля 2019

Я пытаюсь настроить систему push-уведомлений, для этого я использую Firebase Cloud Messaging с Pusher.Я следовал этому руководству , чтобы реализовать его.

При настройке FCM я смог отправлять уведомления с панели управления FCM.Затем, когда я настраиваю Pusher, после получения уведомления мое приложение вылетает.

Я проверил несколько сообщений в Интернете, но не смог найти ни одного, который бы решил мою проблему.Я несколько раз проверял свои зависимости в моих файлах Gradle.

Вот мой MainActivity.java:

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.pusher.pushnotifications.PushNotifications;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        PushNotifications.start(getApplicationContext(), "9e3bfbb7-a6b0-4bcf-aa74-47b4b04fa530");
        PushNotifications.addDeviceInterest("hello");
    }
}

build.gradle (Модуль: приложение) - Зависимости

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    //noinspection GradleCompatible
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    implementation 'com.google.firebase:firebase-messaging:17.6.0'
    implementation 'com.google.firebase:firebase-core:16.0.8'
    implementation 'com.google.firebase:firebase-auth:16.2.1'
    implementation 'com.pusher:push-notifications-android:1.4.0'

    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'
}

Чтобы отправить уведомление, я использую команду curl, предоставленную веб-сайтом Pusher:

curl -H "Content-Type: application/json"      -H "Authorization: Bearer 99E1F894C23ECD14DE98003053B3AFC1D3A4335C97C0D1DF5E1105C719979CA3"      -X POST "https://9e3bfbb7-a6b0-4bcf-aa74-47b4b04fa530.pushnotifications.pusher.com/publish_api/v1/instances/9e3bfbb7-a6b0-4bcf-aa74-47b4b04fa530/publishes"      -d '{"interests":["hello"],"fcm":{"notification":{"title":"Hello","body":"Hello, world!"}}}'

Мое приложение обнаруживает уведомление, но при его получении происходит сбой, возникает ошибка:

I/FCMMessageReceiver: Got a valid pusher message.
E/AndroidRuntime: FATAL EXCEPTION: Firebase-WrappedFirebaseMessagingService
    Process: com.example.fcmapp, PID: 10924
    java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Context.getPackageName()' on a null object reference
        at android.content.ContextWrapper.getPackageName(ContextWrapper.java:142)
        at com.google.firebase.messaging.zzb.<init>(Unknown Source:5)
        at com.google.firebase.messaging.FirebaseMessagingService.zzd(Unknown Source:58)
        at com.google.firebase.iid.zzb.run(Unknown Source:2)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
        at com.google.android.gms.common.util.concurrent.zza.run(Unknown Source:6)
        at java.lang.Thread.run(Thread.java:764)

1 Ответ

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

Я обнаружил точно такую ​​же проблему. Я вернулся на com.google.firebase:firebase-messaging:17.5.0. Проблема решена.

...