0

내 안드로이드 기기에서 푸시 알림을 수신하려면 this 튜토리얼을 따르고 있습니다.onMessageReceived가 전경 앱인 경우 시작되지 않음

Firebase 콘솔에서 푸시 알림을 보낼 수 있으며 logcat에서 Firebase 이벤트도 볼 수 있지만 onMessageReceived은 절대로 실행되지 않습니다. 내 앱이 포 그라운드에서 실행 중입니다.

12-31 12:23:54.741 9453-11132/com.example.app D/FA: Logging event (FE): notification_receive(_nr), Bundle[{firebase_event_origin(_o)=fcm, firebase_screen_class(_sc)=MainActivity, firebase_screen_id(_si)=407943440756026938, message_device_time(_ndt)=0, message_name(_nmn)=Label Arse, message_time(_nmt)=1514723034, message_id(_nmid)=3115372290763926350}] 
12-31 12:23:54.784 9453-11132/com.example.app V/FA: Connecting to remote service 
12-31 12:23:54.797 9453-11132/com.example.app D/FA: Logging event (FE): notification_foreground(_nf), Bundle[{firebase_event_origin(_o)=fcm, firebase_screen_class(_sc)=MainActivity, firebase_screen_id(_si)=407943440756026938, message_device_time(_ndt)=0, message_name(_nmn)=Label Arse, message_time(_nmt)=1514723034, message_id(_nmid)=3115372290763926350}] 
12-31 12:23:54.828 9453-11132/com.example.app V/FA: Connection attempt already in progress 
12-31 12:23:54.829 9453-11132/com.example.app D/FA: Connected to remote service 
12-31 12:23:54.829 9453-11132/com.example.app V/FA: Processing queued up service tasks: 2 
12-31 12:23:59.875 9453-11132/com.example.app V/FA: Inactivity, disconnecting from the service 

MyFirebaseMessageingService.java

public class MyFirebaseMessagingService extends FirebaseMessagingService { 
    private static final String TAG = "FCM Service"; 
    @Override 
    public void onMessageReceived(RemoteMessage remoteMessage) { 
     Log.d(TAG, "From: " + remoteMessage.getFrom()); 
     Log.d(TAG, "Notification Message Body: " + remoteMessage.getNotification().getBody()); 
    } 
} 

FirebaseIDService.java

public class FirebaseIDService extends FirebaseInstanceIdService { 
    private static final String TAG = "FirebaseIDService"; 

    @Override 
    public void onTokenRefresh() { 
     String refreshedToken = FirebaseInstanceId.getInstance().getToken(); 
     Log.d(TAG, "Refreshed token: " + refreshedToken); 

     sendRegistrationToServer(refreshedToken); 
    } 

    private void sendRegistrationToServer(String token) { 
     // Add custom implementation, as needed. 
    } 
} 

의 AndroidManifest.xml : I는 통지를 송신 한 후 여기

는 로그 캣에 출력

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.example.app"> 

    <uses-permission android:name="android.permission.INTERNET" /> 

    <application 
     android:allowBackup="true" 
     android:hardwareAccelerated="false" 
     android:icon="@mipmap/ic_launcher" 
     android:label="@string/app_name" 
     android:supportsRtl="true" 
     android:theme="@style/AppTheme"> 
     <activity 
      android:name=".MainActivity" 
      android:windowSoftInputMode="stateHidden"> 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 
       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 

     <service 
      android:name=".services.MyFirebaseMessagingService" 
      android:enabled="true" 
      android:exported="true" /> 
     <service 
      android:name=".services.FirebaseIDService" 
      android:enabled="true" 
      android:exported="true"></service> 
    </application> 
</manifest> 

firebase messaging guide

함께 매니페스트 파일에 서비스 태그를 교체하려고 구글에 따라 build.gradle

apply plugin: 'com.android.application' 

android { 
    compileSdkVersion 25 
    buildToolsVersion '26.0.2' 

    defaultConfig { 
     applicationId "com.example.app" 
     minSdkVersion 17 
     targetSdkVersion 23 
     versionCode 1 
     versionName "1.0" 
    } 
    buildTypes { 
     release { 
      minifyEnabled false 
      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 
     } 
    } 
    sourceSets { 
     main { 
      java.srcDirs = ['src/main/java', 'src/main/java/services'] 
     } 
    } 
} 

repositories { 
    maven { url "https://jitpack.io" } 
} 

dependencies { 
    implementation 'com.android.support.constraint:constraint-layout:1.0.2' 
    implementation 'com.google.firebase:firebase-messaging:11.8.0' 
    compile fileTree(include: ['*.jar'], dir: 'libs') 
    compile 'com.android.volley:volley:1.1.0' 
    compile 'com.google.code.gson:gson:2.8.2' 
    compile 'com.github.PhilJay:MPAndroidChart:v2.1.6' 
    testCompile 'junit:junit:4.12' 
    compile 'com.android.support:appcompat-v7:25.4.0' 
    compile 'com.google.firebase:firebase-appindexing:11.8.0' 
    compile files('libs/glide-full-4.3.1.jar') 
} 


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

답변

4

다음 onMessageReceived에

<service 
    android:name=".MyFirebaseMessagingService"> 
    <intent-filter> 
     <action android:name="com.google.firebase.MESSAGING_EVENT"/> 
    </intent-filter> 
</service> 

<service 
    android:name=".MyFirebaseInstanceIDService"> 
    <intent-filter> 
     <action android:name="com.google.firebase.INSTANCE_ID_EVENT"/> 
    </intent-filter> 
</service> 

() refer here 당신이 얻을 수 알림/데이터 페이로드 :

public class MyFirebaseMessagingService extends FirebaseMessagingService { 
    private static final String TAG = "FCM Service"; 

    @Override 
    public void onMessageReceived(RemoteMessage remoteMessage) { 
     if (remoteMessage.getData().size() > 0) { 
      Log.d(TAG, "Message data payload: " + remoteMessage.getData()); 
     } 

     if (remoteMessage.getNotification() != null) { 
      Log.d(TAG, "Message Notification Body: " + 
        remoteMessage.getNotification().getBody()); 
     } 

    } 

} 
+0

정확히 그게 고마워. – TomSelleck

+0

감사합니다. 너는 내 시간을 절약한다. –