Android个推快速集成

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

个推官网:个推官网

android文档:android 个推文档

推送的Json串中带url时踩过的坑:JsonObject解析url报Method threw 'org.json.JSONException' exception.

1、创建个推应用

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

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

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、添加权限声明













































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:64
64
hdpi:9696
xhdpi:128
128
xxhdpi:192*192

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

ldpi:1818
mdpi:24
24
hdpi:3636
xhdpi:48
48
xxhdpi:7272
xxxhdp:96
96

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已经成功运行起来了,去后台推送就行了:


image

你可能感兴趣的:(Android个推快速集成)