融云通知栏push和onReceived重复解决方案

融云通知栏push和onReceived重复解决方案

业务需求

根据系统推送过来的信息内容跳到特定页面

吐槽,吐槽,吐槽

1.通知栏的显示可以有两个通道内容来控制
2.点完push的信息,进应用后onReceived还会再收到一条同样的内容,如果这时要处理你自己的跳转,就坑了。就算不点进来,你直接点桌面的应用,也会同样的问题
3.onNotificationMessageClicked()方法中的message内容,push的内容和onReceived的内容还不一样,但是它点击都经过这方法。message.getPushData()内容是不一样的,控制跳转内容又存在getPushData()里面
4.onNotificationMessageArrived()不是每条push信息来都调用,还分手机的。照道理通知栏内容你都能封装上去。这里就没法弄?一定要开启自启动权限…
5.每次问问题都叫我看demo,能看出来就不用问你了啊

暂时的解决方案

基本知识:return true 就不会弹通知栏
基本思路:
1、push过的信息onReceived就不处理
2、刚启动应用onReceived不处理信息
3、用SP来存储数据,最好结合接口给唯一值

部分代码

SealNotificationReceiver

@Override
public boolean onNotificationMessageArrived(Context context, PushNotificationMessage message) {

    String transactionId;
    if (null != message.getPushData() && Utils.isJson(message.getPushData())) {
        try {
            JSONObject object = new JSONObject(message.getPushData());

            transactionId = object.isNull("transactionId") ? "" : object.getString("transactionId");
            if(!TextUtils.isEmpty(transactionId)){
                 //保存push过来的id,唯一值,在onRecevied会用到
                SPInfo.saveNodeNotificationId(context,transactionId);

            }
        } catch (JSONException e) {
            e.printStackTrace();
        }

    }

    return false;
}


@Override
public boolean onNotificationMessageClicked(Context context, PushNotificationMessage message) {
    LogUtils.i("pushExtra", "onNotificationMessageClicked" + "\t" + message.getTargetId() + "\t" + message.getExtra() + "\t" + message.getPushContent() + "\t" + message.getPushData() +
            "\t"+message.getPushId());

    String transactionId;

    if (null != message.getPushData() && Utils.isJson(message.getPushData())) {
        try {
            JSONObject object = new JSONObject(message.getPushData());

            transactionId = object.isNull("transactionId") ? "" : object.getString("transactionId");
            //点击中也添加,防止onNotificationMessageArrived没调
            if(&& !TextUtils.isEmpty(transactionId)){
                SPInfo.saveNodeNotificationId(context,transactionId);

            }
        } catch (JSONException e) {
            e.printStackTrace();
        }

    }

**在onReceived()中
jump为false会走融云默认处理方式,为true自己处理**

//设置跳转
                        if((null != SPInfo.getNodeNotificationIds(mContext) && !SPInfo.getNodeNotificationIds(mContext).isEmpty()
                                && SPInfo.getNodeNotificationIds(mContext).contains(transactionId)) || SPUtils.getBoolean(mContext,SPKey.START_APP_FLAG,false)){
                            LogUtils.i("spNodes",SPInfo.getNodeNotificationIds(mContext).toString());
                            //通知栏通过push已经有,返回true不处理,消除本地记录id
                            //或者刚启动应用,返回true不处理
                            jump = true;
                            SPInfo.cleanNodeNotificationId(mContext,transactionId);
                            SPUtils.saveBoolean(mContext, SPKey.START_APP_FLAG,false);
                        } else {
                            jump = setJump(app_node,tm.getContent());
                        }

差不多就解决了,只是暂时的解决方案。主要是思路,思路,思路

有问题或者更好的解决方案,加我Q:893151960

猜你喜欢

转载自blog.csdn.net/u010074743/article/details/81088924