Как сделать так, чтобы сервис уведомлений Android FCM всегда работал в фоновом режиме? - PullRequest
0 голосов
/ 16 мая 2018

В настоящее время я работаю над приложением, которое работает с темами, чтобы информировать пользователей о новых изменениях. Это на самом деле работает довольно хорошо, но только если приложение в данный момент работает. Если приложение находится в фоновом режиме или закрыто, уведомление не отправляется. И это то, что я хочу изменить. Приложение / служба уведомлений всегда должно работать в фоновом режиме.

Я уже нашел некоторые решения для SO, но не были ли они решениями «сервер-клиент» (с FCM), или они действительно не работали.

это FCM / Notification-Class , работающий на моем сервере:

public static void pushFCMNotification(String DeviceIdKey, String title, String content) throws Exception {

    String authKey = AUTH_KEY_FCM;
    String FMCurl = API_URL_FCM;

    URL url = new URL(FMCurl);
    HttpURLConnection conn = (HttpURLConnection) url.openConnection();

    conn.setUseCaches(false);
    conn.setDoInput(true);
    conn.setDoOutput(true);

    conn.setRequestMethod("POST");
    conn.setRequestProperty("Authorization", "key=" + authKey);
    conn.setRequestProperty("Content-Type", "application/json");

    JSONObject data = new JSONObject();
    data.put("to", DeviceIdKey.trim());
    JSONObject info = new JSONObject();
    info.put("title", title); // Notification title
    info.put("content-text", content); // Notification body
    info.put("click_action", ".MainActivity");
    data.put("data", info);


    System.out.println(data.toString());
    OutputStreamWriter wr = new OutputStreamWriter(conn.getOutputStream());
    wr.write(data.toString());
    wr.flush();
    wr.close();



    int responseCode = conn.getResponseCode();
    System.out.println("Response Code : " + responseCode);

    BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
    String inputLine;
    StringBuffer response = new StringBuffer();

    while ((inputLine = in.readLine()) != null) {
        response.append(inputLine);
    }
    in.close();

}

//test method
public static void main(String[] args) throws Exception {
    DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
    Date date = new Date();
    FCMNotification.pushFCMNotification("/topics/general",   dateFormat.format(date), "dracky");
}
}

Это мои классы FCM, работающие на Android:

1. FCM_Instance_ID_Service.java

открытый класс FCM_Instance_ID_Service extends FirebaseInstanceIdService { final String tokenPreferenceKey = "fcm_token";

final static String infoTopicName = "info";

private static final String REG_TOKEN = "REG_TOKEN";

@Override
public void onTokenRefresh() {

    super.onTokenRefresh();
    SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);
    sharedPreferences.edit().putString(tokenPreferenceKey, FirebaseInstanceId.getInstance().getToken()).apply();

    FirebaseMessaging.getInstance().subscribeToTopic(infoTopicName);

}
}

2. FCM_Messaging_Service.java

public class FCM_Messaging_Service extends FirebaseMessagingService {

@Override
public void onMessageReceived(RemoteMessage remoteMessage) {

    super.onMessageReceived(remoteMessage);

    if (remoteMessage.getFrom().equals("/topics/" + FCM_Instance_ID_Service.infoTopicName)) {
        displayNoification(remoteMessage.getData().get("title"), remoteMessage.getData().get("content-text"), this);

    } else {
        displayNoification(remoteMessage.getData().get("title"), remoteMessage.getData().get("content-text"), this);
    }

    Vibrator v = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE);
    // Vibrate for 500 milliseconds
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
        v.vibrate(VibrationEffect.createOneShot(500, VibrationEffect.DEFAULT_AMPLITUDE));
    } else {
        //deprecated in API 26
        v.vibrate(500);
    }

    //startAlarm(true, false);
    }


@SuppressLint("NewApi")
public void displayNoification(String title, String contentText, Context context) {
    Notification notification = null;

    notification = new Notification.Builder(this)
            .setContentTitle(title)
            .setContentText(contentText)
            .setSmallIcon(R.mipmap.ic_launcher_round)

            .setLights(Color.RED, 3000, 3000)
            .setSound(Uri.parse("android.resource://"
                    + context.getPackageName() + "/" + R.raw.alarm))
            .setLargeIcon(BitmapFactory.decodeResource(
                    getResources(), R.mipmap.ic_launcher))
            .build();


    NotificationManager notificationManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
    notificationManager.notify(14, notification);
}
}

Это мой manifest.xml

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

    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
            <intent-filter>
                <action android:name=".MainActivity" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>

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

        <activity android:name=".BrowserActivity" />
        <activity android:name=".ReviewActivity" />
        <activity android:name=".WatchListActivity"></activity>
    </application>

</manifest>

У кого-нибудь есть идея?

1 Ответ

0 голосов
/ 16 мая 2018

Я думаю, что это не проблема FCM или службы уведомлений. Я думаю, что это проблема некоторых устройств. Проверьте мой ответ в аналогичном посте, и, возможно, это поможет вам.

Уведомления не получены на Android

...