项目中要求集成极光推送 在看文当时发现极光提供了一种jcenter自动集成的方式,相对于之前的手动集成方式,这种方法真的是简单方便,不必在大面积复制粘贴了
下面把集成步骤记录一下 :
1.配置jcenter支持
在Project 根目录的主 gradle 中配置了jcenter支持(新建project默认配置就支持)
build.gradle
buildscript {
repositories {
jcenter()
}
}
allprojets {
repositories {
jcenter()
}
}
在Moudle的gradle中添加依赖和AndroidManifest的替换变量。
android {
defaultConfig {
applicationId "com.xxx.xxx" //JPush上注册的包名.
ndk {
//选择要添加的对应cpu类型的.so库。
abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a'
// 还可以添加 'x86', 'x86_64', 'mips', 'mips64'
}
manifestPlaceholders = [
JPUSH_PKGNAME : applicationId, //JPush上注册的包名.
JPUSH_APPKEY : "你的appkey", //JPush上注册的包名对应的appkey.
JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.
]
}
}
dependencies {
......
compile 'cn.jiguang.sdk:jpush:3.1.3' // 此处以JPush 3.1.3 版本为例。
compile 'cn.jiguang.sdk:jcore:1.2.1' // 此处以JCore 1.2.1 版本为例。
......
}
项目开发过程中一般都有开发环境和生产环境,这两者的有时候为了方便区分包名会不一样,这也导致开发环境和生产环境所申请的KEY是不一样的,所以这种情况为了不用每次打包的时候都去改KEY,可以按照下面的方式添加依赖。
android {
defaultConfig {
ndk {
//选择要添加的对应cpu类型的.so库。
abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a'
// 还可以添加 'x86', 'x86_64', 'mips', 'mips64'
}
}
buildTypes {
debug {
//测试环境
applicationId "com.xxx.xxx" //JPush上注册的包名.
manifestPlaceholders = [
JPUSH_PKGNAME : applicationId, //JPush上注册的包名.
JPUSH_APPKEY : "你的appkey", //JPush上注册的包名对应的appkey.
JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.
]
}
release {
//生产环境
applicationId "com.xxx.xxx" //JPush上注册的包名.
manifestPlaceholders = [
JPUSH_PKGNAME : applicationId, //JPush上注册的包名.
JPUSH_APPKEY : "你的appkey", //JPush上注册的包名对应的appkey.
JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.
]
}
}
dependencies {
......
compile 'cn.jiguang.sdk:jpush:3.1.3' // 此处以JPush 3.1.3 版本为例。
compile 'cn.jiguang.sdk:jcore:1.2.1' // 此处以JCore 1.2.1 版本为例。
......
}
注 : 如果在添加以上 abiFilter 配置之后android Studio出现以下提示:
NDK integration is deprecated in the current plugin. Consider trying the new experimental plugin
则在 Project 根目录的gradle.properties文件中添加:
android.useDeprecatedNdk=true
这种情况基本上不会出现,只有用到NDK时才有可能遇到
在 proguard-rules.pro 文件中加入混淆代码
-dontoptimize
-dontpreverify
-dontwarn cn.jpush.**
-keep class cn.jpush.** { *; }
-keep class * extends cn.jpush.android.helpers.JPushMessageReceiver { *; }
-dontwarn cn.jiguang.**
-keep class cn.jiguang.** { *; }
在自定义的Application中onCreate中调用极光推送的初始化方法。
public class JPushApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
JPushInterface.setDebugMode(true); //正式环境时去掉此行代码
JPushInterface.init(this);
}
}
然后在 AndroidManifest.xml 文件中关联JPushApplication
根据需求添加权限
自定义广播接收器,官方Demo已给出(这里已简化)
/**
* 自定义JPush接收器
*
* 如果不定义这个 Receiver,则:
* 1) 默认用户会打开主界面
* 2) 接收不到自定义消息
*/
public class JPushReceiver extends BroadcastReceiver {
private static final String TAG = "JIGUANG-Example";
@Override
public void onReceive(Context context, Intent intent) {
try {
Bundle bundle = intent.getExtras();
if (JPushInterface.ACTION_REGISTRATION_ID.equals(intent.getAction())) {
//极光服务器分配的Registration Id,
String regId = bundle.getString(JPushInterface.EXTRA_REGISTRATION_ID);
} else if (JPushInterface.ACTION_MESSAGE_RECEIVED.equals(intent.getAction())) {
//自定义消息
} else if (JPushInterface.ACTION_NOTIFICATION_RECEIVED.equals(intent.getAction())) {
//推送通知
} else if (JPushInterface.ACTION_NOTIFICATION_OPENED.equals(intent.getAction())) {
//当用户点击通知时的操作,打开自定义的Activity
Intent i = new Intent(context, TestActivity.class);
i.putExtras(bundle);
i.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);
context.startActivity(i);
}
} catch (Exception e) {
}
}
}
然后在 AndroidManifest.xml 文件中声明JPushReceiver
到这里关于极光推送的集成就已经完成了,可以在极光推送后台发生条推送测试一下了。