2

react native 整合极光推送(Android)

最近项目中需要用到通知,综合比较决定使用极光推送,看了看网上的教程好像都没有一个整合好的例子,或者是步骤有些问题,自己也折腾了很长时间,在此把极光推送配置的步骤整理一下,提供给各位有需要的朋友

一.安装
我的react native使用的是最新版本0.43.3,对应的极光推送需要同时安装jpush和jcore,

npm install jcore-react-native --save
npm install jpush-react-native --save
react-native link

二.配置

1、在android/app/build.gradle里android>>defaultConfig中加入:

    manifestPlaceholders = [
      JPUSH_APPKEY: "yourAppKey", //在极光推送后台申请的APPKey
      APP_CHANNEL: "developer-default"   
      ]

在dependencies中加入:(link后自动加入,需检查)

  compile project(':jpush-react-native')  // 添加 jpush 依赖
  compile project(':jcore-react-native')

2、在项目的settings.gradle中加入(link后自动加入,需检查):

include ':app', ':jpush-react-native', ':jcore-react-native'
project(':jpush-react-native').projectDir = new File(rootProject.projectDir, '../node_modules/jpush-react-native/android')
project(':jcore-react-native').projectDir = new File(rootProject.projectDir, '../node_modules/jcore-react-native/android')

3、在android/app/manifests/AndroidManifests.xml的<application>加入:

  <meta-data android:name="JPUSH_CHANNEL" android:value="${APP_CHANNEL}"/>
  <meta-data android:name="JPUSH_APPKEY" android:value="${JPUSH_APPKEY}"/>
并在上方加入极光推送权限:
<permission
    android:name="${applicationId}.permission.JPUSH_MESSAGE"
    android:protectionLevel="signature" />

4、在MainActivity中加入如下代码:

  @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        JPushInterface.init(this);
    }
    @Override
    protected void onPause() {
        super.onPause();
        JPushInterface.onPause(this);
    }
    @Override
    protected void onResume() {
        super.onResume();
        JPushInterface.onResume(this);
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
    }

5、在MainApplication类里加入如下代码:

private boolean SHUTDOWN_TOAST = false;
private boolean SHUTDOWN_LOG = false;

在getPackages()方法中加入:

new JPushPackage(SHUTDOWN_TOAST, SHUTDOWN_LOG)

至此,native端需要配置的工作已经全部完成,此时就可以用js进行调用。

demo的代码已上传到GitHub,下下来直接npm install就行,以上就是react native 极光推送的安装配置过程。


zorroyz
25 声望7 粉丝