我使用IntentService处理来自FCM推送通知的消息。当消息逐个出现时,它可以完美地工作,但是当设备未连接到网络时以及设备再次连接后,FCM一次发送大量消息,并且在这种情况下,服务会在处理意图数据时导致一些模糊不清在调用Web服务时会导致意外行为。
我的推送通知消息处理程序类:
public class PushMessageHandler extends FirebaseMessagingService {
private final static String TAG = "PushMessageHandler";
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
super.onMessageReceived(remoteMessage);
if (remoteMessage.getData() != null){
Log.d(TAG, String.valueOf(remoteMessage.getData()));
Intent notificationService = new Intent(this, NotificationService.class);
notificationService.putExtra(ResponseConstants.NOTIFICATION_FIELD,remoteMessage.getData().get(ResponseConstants.NOTIFICATION_FIELD));
notificationService.putExtra(ResponseConstants.NOTIFICATION_DATA,remoteMessage.getData().get(ResponseConstants.NOTIFICATION_DATA));
notificationService.putExtra(ResponseConstants.NOTIFICATION_TYPE,remoteMessage.getData().get(ResponseConstants.NOTIFICATION_TYPE));
try {
notificationService.putExtra(ResponseConstants.NOTIFICATION_IMAGE,remoteMessage.getData().get(ResponseConstants.NOTIFICATION_IMAGE));
notificationService.putExtra(ResponseConstants.NOTIFICATION_TITLE, remoteMessage.getData().get(ResponseConstants.NOTIFICATION_TITLE));
} catch (Exception e){
Crashlytics.logException(e);
}
try {
notificationService.putExtra(ResponseConstants.DATASETS,remoteMessage.getData().get(ResponseConstants.DATASETS));
} catch (Exception e){
Crashlytics.logException(e);
}
startService(notificationService);
} else {
Log.d(TAG, "Notification data is null");
}
}
}
我的通知处理程序服务类:
public class NotificationService extends IntentService implements NotificationContract.View {
@Inject
public NotificationPresenter mNotificationPresenter;
private NotificationContract.Presenter mPresenter;
private static final String TAG = "NotificationService";
private Intent mIntent;
public NotificationService() {
super("NotificationService");
}
@Override
protected void onHandleIntent(@Nullable Intent intent) {
mIntent = intent;
DaggerNotificationPresenterComponent.builder()
.notificationViewModule(new NotificationViewModule(this))
.remoteDataSourceComponent(MyApplication.getInstance().providesRemoteDataSource())
.localDataSourceComponent(MyApplication.getInstance().providesLocalDataSource())
.build().inject(this);
}
@Override
public synchronized void setPresenter(NotificationContract.Presenter presenter) {
this.mPresenter = presenter;
final String notificationField = mIntent.getStringExtra(ResponseConstants.NOTIFICATION_FIELD);
Log.d(TAG, notificationField);
Handler handler = new Handler(getMainLooper());
handler.post(new Runnable() {
@Override
public void run() {
switch (notificationField.trim()){
case Constants.NOTIFICATION_FIELD_CACHEHOMEFEEDS :
mPresenter.prefetchData(Integer.parseInt(
mIntent.getStringExtra(ResponseConstants.NOTIFICATION_DATA)),
new JSONObject(mIntent.getStringExtra(ResponseConstants.DATASETS)));
break;
case Constants.NOTIFICATION_FIELD_UPDATEFEEDS :
mPresenter.getPostDetailById(Integer.parseInt(
mIntent.getStringExtra(ResponseConstants.NOTIFICATION_DATA)),
new JSONObject(mIntent.getStringExtra(ResponseConstants.DATASETS)));
break;
case Constants.NOTIFICATION_FIELD_ARTICLES :
mPresenter.getPostDetailsPostUrl(mIntent.getStringExtra(ResponseConstants.NOTIFICATION_DATA));
break;
case Constants.NOTIFICATION_FIELD_POSTDELETED :
mPresenter.deleteFeed(Integer.parseInt(
mIntent.getStringExtra(ResponseConstants.NOTIFICATION_DATA)));
break;
}
}
});
}
}
在批量推送消息的情况下,我获得了NOTIFICATION_DATA的可互换值,即我在通知字段为" NOTIFICATION_FIELD_CACHEHOMEFEEDS"时所预期的值。是"发布:1234"并且对于字段" NOTIFICATION_FIELD_ARTICLES"是"发布:' post-URL'"但我得到的是:#1234"对于提交" NOTIFICATION_FIELD_ARTICLES",该值在任何顺序中都可以互换,这取决于推送通知的消息调用。
根据IntentService的文档,以队列方式逐个处理请求。那么为什么会这样呢。有没有办法完美地处理这个问题。
答案 0 :(得分:2)
IntentService - > onHandleIntent在后台线程上执行。如果您有耗时的操作,您应该在那里执行它。 如果不是 - 只需使用正常的服务。
现在在onHandleIntent中,您将从后台线程多次注入演示者 - 我认为您应该将注入移动到构造函数。 然后在onHandleIntent中调用您的presenter方法(mPresenter.prefetchData,mPresenter.getPostDetailById等)。