Android信鸽推送全解
来源:互联网 发布:微销通软件下载 编辑:程序博客网 时间:2024/05/16 18:55
Android开发中集成信鸽推送还是比较简单的,但是遇到了坑就麻烦
先介绍一下集成信鸽推送的步骤
1.build文件中添加依赖
//信鸽的版本 compile 'com.tencent.xinge:xinge:3.1.1-alpha' //mid包的版本 compile 'com.tencent.mid:mid:3.721-alpha'
2.添加自定义广播MessageReceiver接收推送消息
<!-- APP实现的Receiver,用于接收消息和结果反馈 --> <!-- com.tencent.android.xgpushdemo.CustomPushReceiver需要改为自己的Receiver --> <receiver android:name=".third.push.MessageReceiver" android:exported="true" > <intent-filter> <!-- 接收消息透传 --> <action android:name="com.tencent.android.tpush.action.PUSH_MESSAGE" /> <!-- 监听注册、反注册、设置/删除标签、通知被点击等处理结果 --> <action android:name="com.tencent.android.tpush.action.FEEDBACK" /> </intent-filter> </receiver>
3.在MessageReceiver中收到通知后的操作
// 收到通知后的操作, @Override public void onNotifactionShowedResult(Context context, XGPushShowedResult notifiShowedRlt) { if (context == null || notifiShowedRlt == null) { return; } LogUtils.i("--------messageReciver----result---------------" + notifiShowedRlt); PreferenceUtil pUtil = PreferenceUtil.getInstance(); context.sendBroadcast(reciverIntent); int countMention = pUtil.getNoReadMsg(); countMention++; pUtil.setNoReadMsg(countMention); String strJSON = notifiShowedRlt.getCustomContent(); JSONObject object = JSON.parseObject(strJSON); int type = object.getIntValue("category"); switch (type) { case MessageBean.MSG_TYPE_SHIELD: //屏蔽用户,需要退出登录 break; case MessageBean.MSG_TYPE_BLACK_YELLOW_LIST: //黄黑名单用户 break; case MessageBean.MSG_TYPE_BANNED_SAY: //禁言用户 break; case MessageBean.MSG_UPDATE_KEY: //更改密钥 break; } //刷新一下未读消息 OtherRequest.getInstance().getUnReadLog(pUtil, pUtil.getUserToken()); }
4.点击通知栏进入不同详情:
/** * 点击不同类型通知,进入不同详情 * * @param context * @param message */ @Override public void onNotifactionClickedResult(Context context, XGPushClickedResult message) { if (context == null || message == null) { return; } LogUtils.i("--------onNotifactionClickedResult----result---------------" + message); String strJSON = message.getCustomContent(); JSONObject object = JSON.parseObject(strJSON); int type = object.getIntValue("category"); int bsnId = object.getIntValue("bsnId"); int extId = object.getIntValue("extId"); switch (type) { case MessageBean.MSG_TYPE_LOTTERY: GetLotteryActivity.enterActivity(context, bsnId, extId); break; case MessageBean.MSG_TYPE_SYSTEM: case MessageBean.MSG_TYPE_SHIELD: case MessageBean.MSG_TYPE_BLACK_YELLOW_LIST: case MessageBean.MSG_TYPE_BANNED_SAY: Intent intentMsg = new Intent(context, MessageActivity.class); context.startActivity(intentMsg); break; case MessageBean.MSG_DRAW_NOTIFY: Intent drawIntent = new Intent(context, UserDrawLogActivity.class); context.startActivity(drawIntent); break; } }
第五步,信鸽推送的注册与反注册
//注册信鸽推送,绑定推送账号 XGPushManager.registerPush(mActivity.getApplicationContext(), String.valueOf(userId));//注册信鸽推送,解绑推送账号 XGPushManager.unregisterPush(activity.getApplicationContext());
这样信鸽推送基本集成完毕,接下来开始踩坑了.
一坑:收不到推送的消息
自己在信鸽官方平台发一条推送消息给自己,看是否能收到:
1.如果能收到,直接摔锅给后台
2.如果不能收到,
1. 检查自己的token是否配置正确
2. 检查自己是否有注册
二坑:点击通知栏通知后,进入自己指定的界面后,又重新打开了App
自己在信鸽官方平台高级设置里面的DeepLink 指定自己要打开的Activity,发一条推送消息给自己,看是否能正常打开:
1.如果能收到且正常打开,直接摔锅给后台
2.如果不能收到,告诉后台:1. 后台是否有指定正确的Activity. 2. 后台如果不指定Activity,则会启动App,没有进入我们指定的activity 3. 后台不需要指定包名。
三坑:点击通知栏通知后,进入自己指定的界面后,再按返回,发现回到自己指定的Activity中
我指定一个推送界面MessageActivity,点击通知栏,进入了新的指定界面OrderActivity,我再返回的时候,他进入了我指定的推送界面MessageActivity,其实这个时候完全不需要进入这个MessageActivity,我咨询了信鸽官方,他们说确实存在这样的bug.于是我自己整理了一个解决方案.
/** * 点击不同类型通知,进入不能详情 * * @param context * @param message */ @Override public void onNotifactionClickedResult(Context context, XGPushClickedResult message) { if (context == null || message == null) { return; } LogUtils.i("--------onNotifactionClickedResult----result---------------" + message); String strJSON = message.getCustomContent(); String activityName = message.getActivityName(); //注意这里的ActivityName是一个全路径的
这里可以获取到activityName,我们只需要把这个指定的activityName**(我这里是MessageActivity)**对应的activity关掉就可以了。
但这里要注意关掉的时机,会发现只有在执行跳入新界面(OrderActivity)的时候才会打开那个MessageActivity. 所以我们可以在打开OrderActivity后手动关掉MessageActivity.这样就避免了一个多余的界面,且也不会对用户造成影响.
/*** * 功能:结束指定activity名称 * 创建时间: 2017/7/28 15:15 * @param ***/ public void finishActivityclass(String activityName) { if (activities != null) { for (Activity activity : activities) { StringBuilder sb = new StringBuilder(); sb.append(activity.getPackageName()).append(".").append(activity.getLocalClassName()); if (sb.toString().equals(activityName)) { this.activities.remove(activity); finishActivity(activity); break; } } } } /*** * 功能:这里是关闭信鸽推送指定的Activity,存在的一个bug,这是一个通用的方法, * 创建时间: 2017/7/28 15:01 * @param ***/ public static void closePushActivity(Intent intent) { String activityName = intent.getStringExtra(KEY_OPEN_ACTIVITY); if (!TextUtils.isEmpty(activityName)) { ActivityManagerUtils.getInstance().finishActivityclass(activityName); } }
阅读全文
0 0
- Android信鸽推送全解
- Android Studio 集成信鸽推送
- Android项目集成信鸽推送
- 信鸽推送 Android 跳转Activity
- 信鸽推送
- 信鸽推送
- 信鸽推送
- 信鸽推送
- Android Studio 2.0使用腾讯信鸽推送
- android studio信鸽推送10004错误
- Android项目集成信鸽推送过程详解
- Android应用的信鸽推送集成
- Android 信鸽推送需要注意的细节
- android studio 集成腾讯信鸽实现特定账号推送
- 记录一次Android信鸽推送,跳到指定Activity
- XG(信鸽推送)
- 安卓信鸽推送
- 腾讯信鸽推送
- 内核
- 为什么你用python3.6 编译dbus-python告诉你configure: error: could not find Python headers
- 2017 Multi-University Training Contest
- 聚类
- 基于注解的Spring AOP的配置和使用
- Android信鸽推送全解
- PHP header 的几种用法
- 【react】父子组件之间通讯props
- Spring事务配置的五种方式和spring里面事务的传播属性和事务隔离级别
- 【笔记】Matconvnet在windows8下编译安装过程
- JAVA代理模式之二动态代理JDK详解
- spring集成redis和jms时注意
- 用户资源访问
- 写个自己看的博客_UGUI_DragDrop官网例子