极光推送第一篇:配置

极光推送第二篇:消息处理
极光推送第三篇:消息跳转和自定义

相信很多人都是用的极光推送,因为名字好看。官方也有文档:https://docs.jiguang.cn//jpush/client/Android/android_sdk/,但我觉得太杂太乱了,还是打算自己总结一下自动集成,因为懒,所以不手动。

  • 说明 : 使用 jcenter 自动集成的开发者,不需要在项目中添加 jar 和 so,jcenter 会自动完成依赖;在 AndroidManifest.xml 中不需要添加任何 JPush SDK 相关的配置,jcenter 会自动导入
  • 注意 :如果需要【处理收到的消息】、使用 3.0.7 版本支持的别名与标签的新接口,AndroidManifest 中的自定义广播接收器仍需开发者手动配置,参考 SDK 压缩包里的 AndroidManifest.xml 样例文件。
1.引入sdk:极光现在采用模块化引入,所以jcore核心是所有的极光服务都要引入的,然后我们只需要再引入推送jpush就可以了:
  • a.在dependencies引入相关的SDK
implementation 'cn.jiguang.sdk:jpush:3.3.2'
implementation 'cn.jiguang.sdk:jcore:2.0.1'
  • b.在android{defaultConfig{}}中配置:ndk(cup的支持)
        ndk {
            //选择要添加的对应 cpu 类型的 .so 库。
            abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a','x86', 'x86_64', 'mips', 'mips64'
        }
  • c.在android{defaultConfig{}}中配置:manifestPlaceholders(包名,key,渠道)
        manifestPlaceholders = [
            JPUSH_PKGNAME : applicationId,
            JPUSH_APPKEY : "你的 Appkey ", //JPush 上注册的包名对应的 Appkey.
            JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.
        ]
2.配置JCommonService:说好的在 AndroidManifest.xml 中不需要添加配置,但【极光】说:使用 JCore 2.0.0 及以上版本,则需要配置一个Service,才能更稳定。我们肯定希望更稳定啊!所以:

a.在创建自己的PushService

import cn.jpush.android.service.JCommonService;
public class PushService extends JCommonService {
}

b.在AndroidManifest.xml中配置

        <!-- Since JCore2.0.0 Required SDK核心功能-->
        <!-- 可配置android:process参数将Service放在其他进程中;android:enabled属性不能是false -->
        <!-- 这个是自定义Service,要继承极光JCommonService,可以在更多手机平台上使得推送通道保持的更稳定 -->
        <service android:name="com.smallcake.jpush.PushService"
            android:enabled="true"
            android:exported="false"
            android:process=":pushcore">
            <intent-filter>
                <action android:name="cn.jiguang.user.service.action" />
            </intent-filter>
        </service>
3.配置JPushMessageReceiver:说好的在 AndroidManifest.xml 中不需要添加配置,但【极光】说:要自己处理消息,就还是要写一个 广播接收器。我们肯定要自己处理一些消息啊!所以:

a.创建

/**
 * 自定义JPush message 接收器,包括操作tag/alias的结果返回(仅仅包含tag/alias新接口部分)
 * */
public class MyJPushMessageReceiver extends JPushMessageReceiver {
    @Override
    public void onTagOperatorResult(Context context,JPushMessage jPushMessage) {
        super.onTagOperatorResult(context, jPushMessage);
    }
    @Override
    public void onCheckTagOperatorResult(Context context,JPushMessage jPushMessage){
        super.onCheckTagOperatorResult(context, jPushMessage);
    }
    @Override
    public void onAliasOperatorResult(Context context, JPushMessage jPushMessage) {
        super.onAliasOperatorResult(context, jPushMessage);
    }
    @Override
    public void onMobileNumberOperatorResult(Context context, JPushMessage jPushMessage) {
        super.onMobileNumberOperatorResult(context, jPushMessage);
    }
}

b.配置

        <!-- Required since 3.0.7 -->
        <!-- 新的 tag/alias 接口结果返回需要开发者配置一个自定的广播 -->
        <!-- 3.3.0开始所有事件将通过该类回调 -->
        <!-- 该广播需要继承 JPush 提供的 JPushMessageReceiver 类, 并如下新增一个 Intent-Filter -->
        <receiver
            android:name="com.smallcake.jpush.MyJPushMessageReceiver"
            android:enabled="true"
            android:exported="false" >
            <intent-filter>
                <action android:name="cn.jpush.android.intent.RECEIVE_MESSAGE" />
                <category android:name="您应用的包名" />
            </intent-filter>
        </receiver>
4.初始化:在我们自己的Application中初始化,并设置调试开关
JPushInterface.init(this);
JPushInterface.setDebugMode(BuildConfig.DEBUG);

如果你设置了开启混淆minifyEnabled true,记得添加混淆配置:

 #极光推送
-dontoptimize
-dontpreverify
-dontwarn cn.jpush.**
-keep class cn.jpush.** { *; }
-keep class * extends cn.jpush.android.helpers.JPushMessageReceiver { *; }

-dontwarn cn.jiguang.**
-keep class cn.jiguang.** { *; }

配置好这些后,我们去极光后台发送一条消息测试一下,效果如下:


推送测试

下一篇我们来看看消息的处理:

极光推送第二篇:消息处理

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容