android 个推封装,Android个推快速集成

本文详细介绍了Android个推SDK的封装与配置过程。包括创建个推应用,获取AppID、AppKey、AppSecret信息;配置依赖,指定CPU架构和应用参数;添加权限声明,导入通知栏图标;接收推送服务事件,初始化SDK并注册服务;最后通过测试验证SDK是否成功运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

个推真是个磨人的小妖精啊...啊.....

个推官网:个推官网

1、创建个推应用

登录 http://dev.getui.com ,选择登记应用并填写应用名称和包名信息,完成应用创建

182869e54c70?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image

182869e54c70?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image

点击应用配置,获取到相应的AppID、AppKey、AppSecret信息:

182869e54c70?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image

2、配置依赖

添加Maven库地址

在以项目名为命名的顶层build.gradle文件中,添加个推maven库地址,如下所示:

//Maven URL地址

maven {

url "http://mvn.gt.igexin.com/nexus/content/repositories/releases/"

}

在app/build.gradle文件中引用个推SDK依赖库,如下图所示:

dependencies {

implementation 'com.getui:sdk:2.12.5.0'

}

在app/build.gradle文件中的android.defaultConfig下指定所需的 CPU 架构:

android {

...

defaultConfig {

...

ndk {

abiFilters "armeabi", "armeabi-v7a", "x86_64"

}

}

}

配置个推应用参数

在app/build.gradle文件中的android.defaultConfig下添加manifestPlaceholders,配置个推相关的应用参数:

manifestPlaceholders = [

GETUI_APP_ID : "APP_ID",

GETUI_APP_KEY : "APP_KEY",

GETUI_APP_SECRET : "APP_SECRET"

]

请根据在后台创建应用获取到的应用参数进行相应替换APP_ID、APP_KEY、APP_SECRET的值

适配Android P

Android9.0以上默认不支持http通信,为保证SDK正常使用

请在application节点下新增该属性

3、添加权限声明

android:name="getui.permission.GetuiService.${applicationId}"

android:protectionLevel="normal" >

4、导入通知栏图标

为了修改默认的通知图标以及通知栏顶部提示小图标,请在资源目录的res/drawable-ldpi/、res/drawable-mdpi/、res/drawable-hdpi/、res/drawable-xhdpi/、res/drawable-xxhdpi/等各分辨率目录下,放置相应尺寸的文件名为push.png和push_small.png图片

建议的push.png图片尺寸如下 :(但是我好像没遵守也行)

ldpi:4848

mdpi:6464

hdpi:9696

xhdpi:128128

xxhdpi:192*192

建议的push_small.png图片尺寸如下:(但是我好像没遵守也行)

ldpi:1818

mdpi:2424

hdpi:3636

xhdpi:4848

xxhdpi:7272

xxxhdp:9696

5、 接收推送服务事件

在 接收推送服务事件项目源码中添加一个继承自com.igexin.sdk.GTIntentService的类,用于接收CID、透传消息以及其他推送服务事件。请参考下列代码实现各个事件回调方法:

public void onReceiveMessageData(Context context, GTTransmitMessage msg)是透传消息的处理

通知推送时下面有个高级设置,这个里面的透传消息可以在那里设置,如果后端使用的NotificationTemplate模板,那么点击后才会回调此方法,在这个里面可以 进行消息处理并进行分发跳转, 可以用EventBus传递到所有界面透传消息也会传到这个方法里面,绑定别名推送不分IOS还是android,android会直接走到这个里面,会导致自动跳转,透传的message中可以写一个type,标记是android还是IOS,客户端进行判处理(我是这样解决的)

package com.getui.demo;

import android.content.Context;

import android.os.Message;

import android.util.Log;

import com.igexin.sdk.GTIntentService;

import com.igexin.sdk.PushConsts;

import com.igexin.sdk.PushManager;

import com.igexin.sdk.message.FeedbackCmdMessage;

import com.igexin.sdk.message.GTCmdMessage;

import com.igexin.sdk.message.GTTransmitMessage;

import com.igexin.sdk.message.SetTagCmdMessage;

import org.json.JSONObject;

/**

* 继承 GTIntentService 接收来自个推的消息, 所有消息在线程中回调,

* 如果注册了该服务, 则务必要在 AndroidManifest中声明, 否则无法接受消息

*

* onReceiveMessageData 处理透传消息

*

* onReceiveClientId 接收 cid

*

* onReceiveOnlineState cid 离线上线通知

*

* onReceiveCommandResult 各种事件处理回执

*/

public class IntentService extends GTIntentService {

public DemoIntentService() {

}

@Override

public void onReceiveServicePid(Context context, int pid) {

}

@Override

public void onReceiveMessageData(Context context, GTTransmitMessage msg) {

byte[] payload = msg.getPayload();

String message = new String(payload);

Log.i(TAG, "onReceiveMessageData: " + message);

try {

JSONObject json = new JSONObject(message);

String pushType = json.getString("PHONE_TYPE");

if ("ANDROID".equals(pushType)) {

//new UsuallyEvent(message, UsuallyEvent.PUSH)是自己写的Event

EventBus.getDefault().post(new UsuallyEvent(message, UsuallyEvent.PUSH));

}

} catch (Exception e) {

Log.e(TAG, e.toString());

}

}

@Override

public void onReceiveClientId(Context context, String clientid) {

Log.e(TAG, "onReceiveClientId -> " + "clientid = " + clientid);

}

@Override

public void onReceiveOnlineState(Context context, boolean online) {

}

@Override

public void onReceiveCommandResult(Context context, GTCmdMessage cmdMessage) {

}

@Override

public void onNotificationMessageArrived(Context context, GTNotificationMessage msg) {

}

@Override

public void onNotificationMessageClicked(Context context, GTNotificationMessage msg) {

}

}

在AndroidManifest.xml中配置上述 IntentService 类:

6、 初始化SDK并注册com.getui.demo.IntentService

PushManager.getInstance().initialize(this.getApplicationContext(),PushService.class);

// com.getui.demo.IntentService 为第三方自定义的推送服务事件接收类

PushManager.getInstance().registerPushIntentService(this.getApplicationContext(), com.getui.demo.IntentService.class);

7、测试

连接手机或启动Android模拟器,编译运行你的工程,查看logcat信息。在搜索框中输入clientid,如果能显示clientid is xxx日志,则说明个推SDK已经成功运行起来了,去后台推送就行了:

182869e54c70?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值