android信鸽推送demo_腾讯信鸽Android推送集成全解

Android开发中集成信鸽推送还是比较简单的,但是遇到了坑就麻烦

[TOC]

先介绍一下集成信鸽推送的步骤

1.build文件中添加依赖

//信鸽的版本

compile 'com.tencent.xinge:xinge:3.1.1-alpha'

//mid包的版本

compile 'com.tencent.mid:mid:3.721-alpha'

2.添加自定义广播MessageReceiver接收推送消息

android:exported="true"

>

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);

}

}

包含客户端和服务端 代码 亿级并发,秒级触达 稳定的大规模接入集群,同时与数亿移动智能终端保持稳定的长连接,支持十亿级并发 秒级触达用户,每天可发送百亿级的通知/消息 最省电省流量方案 智能识别网络环境,根据不同环境定制通讯协议,以最低消耗维护长连接,做到极致省电省流量 通知及消息高度压缩,节省流量的同时加密保证安全性 丰富标签,精准定向 特定标签人群,团队测试用户,全量用户,单个用户等多种推送范围选择 及时稳定地将信息送达到最相关的用户,形成用户粘性,避免骚扰 开放API接口,灵活自定义推送 开放推送能力,提供多种语言API ,包括Java/PHP/Python/Node.js,业务自由集成 可视效果,实时监控 实时监控通知/消息的抵达用户量,点击转化量,点击转化率,推送效果一目了然 使用方法 登录后,创建应用,获取应用的唯一识别码AccessKey和密钥SecretKey; 下载对应平台的SDK,并参考开发文档完成SDK集成; 通过API调用或Web业务端方便快速地完成推送测试和实际发送,并实时查看推送效果。 使用场景 通知,定义为Android和iOS开发者指南中的Notifidoveion。服务器定向将信息实时送达手机,通过建立一条手机与服务器的连接链路,当有消息需要发送到手机时,通过此链路发送即可。通过推送一条用户可见的信息,引导用户进行有目的性的操作。通常用于产品信息知会、新闻推送和个性化消息等场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值