React Native之通知栏消息提示(android)

博观而约取,厚积而薄发。这篇文章主要讲述React Native之通知栏消息提示(android)相关的知识,希望能为你提供帮助。
React Native之通知栏消息提示(android) 
一,需求分析与概述1.1,推送作为手机应用的基本功能,是手机应用的重要部分,如果自己实现一套推送系统费时费力,所以大部分的应用都会选择使用第三方的推送服务,如极光推送。
1.2,jpush-react-native  是极光推送官方开发的 React Native 版本插件,可以快速集成推送功能。现在最新版本的 JPush SDK 分离了 JPush 及 JCore,让开发者可以分开集成 JMessage 及 JPush(以前 JMessage 包含了 JPush)。
API:

1 #初始化JPush 必须先初始化才能执行其他操作(only android) 2 initPush 3 4 getInfo 5 6 #执行该方法后,无法接收到通知 7 stopPush 8 9 #stopPush后,执行该方法,可接收通知(only android) 10 resumePush 11 12 #参数是func,func的参数是registrationId 13 getRegistrationID 14 15 #设置标签 16 setTags 17 18 #添加标签 19 addTags 20 21 #删除标签 22 deleteTags 23 24 #检查标签的状态 25 checkTagBindState 26 27 #清除所有标签 28 cleanTags 29 30 #设置别名 31 setAlias 32 33 #删除别名 34 deleteAlias 35 36 #获取别名 37 getAlias 38 39 #通知栏样式:Basic 40 setStyleBasic 41 42 #通知栏样式:Custom 43 setStyleCustom

1.3,推送通知可以及时地提醒用户.
二,极光推送注册与集成 2.1,注册
【React Native之通知栏消息提示(android)】首先,登录极光官网系统,如果还没有账号可以注册一个,登录成功我们就可以创建和管理我们的应用了。   
React Native之通知栏消息提示(android)

文章图片

React Native之通知栏消息提示(android)

文章图片

2.2,集成(android)
第一步:安装
打开终端,进入项目根目录文件夹下,执行以下命令:
1npm install jpush-react-native --save 2jpush-react-native 1.4.2 版本以后需要同时安装 jcore-react-native 3npm install jcore-react-native --save

第二步:配置
自动关联配置
1 # 针对性的link,避免之前手动配置的其它插件重复配置造成报错 2react-native link jpush-react-native 3react-native link jcore-react-native

执行完 link 项目后可能会出现报错,这没关系,需要手动配置一下 build.gradle 文件。如自动配置没有成功或没有完善,可根据手动配置检查
手动配置
(1),检查 android 项目下的 settings.gradle 配置有没有包含以下内容(project/android/settings.gradle):
1 include \':jcore-react-native\' 2 project(\':jcore-react-native\').projectDir = new File(rootProject.projectDir, \'../node_modules/jcore-react-native/android\') 3 4 include \':jpush-react-native\' 5 project(\':jpush-react-native\').projectDir = new File(rootProject.projectDir, \'../node_modules/jpush-react-native/android\')

  (2),project/android/app/build.gradle:
1 android { 2... 3defaultConfig { 4applicationId "yourApplicationId" // 此处改成你在极光官网上申请应用时填写的包名 5... 6manifestPlaceholders = [ 7JPUSH_APPKEY: "yourAppKey", //在此替换你极光官网上申请的 APPKey 8APP_CHANNEL: "developer-default"//应用渠道号, 默认即可 9] 10} 11 } 12 ... 13 dependencies { 14compile project(\':jpush-react-native\')// 添加 jpush 依赖 15compile project(\':jcore-react-native\')// 添加 jcore 依赖 16compile fileTree(dir: "libs", include: ["*.jar"]) 17compile "com.android.support:appcompat-v7:23.0.1" 18compile "com.facebook.react:react-native:+"// From node_modules 19 }

(3),检查一下 app 下的 AndroidManifest 配置,有没有增加 < meta-data> 部分。  project/android/app/src/main/AndroidManifest.xml:
1 < application 2... 3< !-- Required . Enable it you can get statistics data with channel --> 4< meta-data android:name="JPUSH_CHANNEL" android:value="https://www.songbingjia.com/android/${APP_CHANNEL}"/> 5< meta-data android:name="JPUSH_APPKEY" android:value="https://www.songbingjia.com/android/${JPUSH_APPKEY}"/> 6 7 < /application>

(4),打开 project/android/app/src/main/java/com/项目名/下的 MainApplication.java 文件,然后加入 JPushPackage
1 ... 2 3 import com.rt2zz.reactnativecontacts.ReactNativeContacts; 4 import cn.jpush.reactnativejpush.JPushPackage; 5 6 ... 7 8 public class MainApplication extends Application implements ReactApplication { 9 // 设置为 true 将不会弹出 toast 10private boolean SHUTDOWN_TOAST = false; 11// 设置为 true 将不会打印 log 12private boolean SHUTDOWN_LOG = false; 13private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) { 14@Override 15public boolean getUseDeveloperSupport() { 16return BuildConfig.DEBUG; 17} 18 19@Override 20protected List< ReactPackage> getPackages() { 21return Arrays.< ReactPackage> asList( 22new MainReactPackage(), 23new JPushPackage(SHUTDOWN_TOAST, SHUTDOWN_LOG) 24); 25} 26 27... 28 29 }

(5),打开  project/android/app/src/main/java/com/项目名/下的MainActivity.java 文件,然后加入 如下代码:
1 ... 2 3 4 import android.os.Bundle; 5 import com.facebook.react.ReactActivity; 6 import cn.jpush.android.api.JPushInterface; 7 8 public class MainActivity extends ReactActivity { 9 10 ... 11 12@Override 13protected void onCreate(Bundle savedInstanceState) { 14super.onCreate(savedInstanceState); 15JPushInterface.init(this); 16} 17 18@Override 19protected void onPause() { 20super.onPause(); 21JPushInterface.onPause(this); 22} 23 24@Override 25protected void onResume() { 26super.onResume(); 27JPushInterface.onResume(this); 28} 29 30@Override 31protected void onDestroy() { 32super.onDestroy(); 33} 34 }

  (6),打开   project/android/app/src/main/下的AndroidManifest.xml 文件,然后添加访问通知的权限:
1 < !--添加通知权限,${ApplicationID}替换成你的applicationID!--> 2< premission 3android:name="${ApplicationID}.permission.JPUSH_MESSAGE" 4android:protectionLevel="signature"/>

  这样就基本完成了所有的配置。接下来就可以在 JS 中调用插件提供的 API 了。
三,使用与实现 3.1,使用
(1),在js中  1 import React, { PureComponent } from \'react\';
2 import { 3Linking, 4Alert 5 } from \'react-native\'; 6 import JPushModule from \'jpush-react-native\' 7 8 ... 9 10 11 componentDidMount() { 12 /****************************通知 start **************************************************/ 13if (Platform.OS === \'android\') { 14JPushModule.initPush() 15// 新版本必需写回调函数 16JPushModule.notifyJSDidLoad(resultCode => { 17if (resultCode === 0) { 18} 19}) 20} else { 21JPushModule.setupPush() 22} 23// 接收自定义消息 24this.receiveCustomMsgListener = map => { 25this.setState({ 26pushMsg: map.content 27}) 28console.log(\'extras: \' + map.extras) 29} 30 31// 接收自定义消息JPushModule.addReceiveCustomMsgListener(this.receiveCustomMsgListener) 32this.receiveNotificationListener = map => { 33console.log(\'alertContent: \' + map.alertContent) 34console.log(\'extras: \' + map.extras) 35} 36// 接收推送通知 37 JPushModule.addReceiveNotificationListener(this.receiveNotificationListener) 38// 打开通知 39this.openNotificationListener = map => { 40// console.log(\'Opening notification!\') 41//console.log(\'map.extra: \' + map.extras) 42let webUrl= JSON.parse(map.extras).webUrl 43let url = webUrl.replace(new RegExp("\\/", \'g\'), "/") 44Linking.canOpenURL(url).then(supported => { 45if (!supported) { 46Alert.alert(\'您的系统不支持打开浏览器!\') 47} else { 48return Linking.openURL(url); 49} 50}).catch(err => { }); 51 52} 53JPushModule.addReceiveOpenNotificationListener(this.openNotificationListener) 54 55// this.getRegistrationIdListener = registrationId => { 56//console.log(\'Device register succeed, registrationId \' + registrationId) 57// } 58// JPushModule.addGetRegistrationIdListener(this.getRegistrationIdListener) 59/****************************通知 end **************************************************/ 60 61 62} 63componentWillUnmount() { 64JPushModule.removeReceiveCustomMsgListener(this.receiveCustomMsgListener) 65JPushModule.removeReceiveNotificationListener(this.receiveNotificationListener) 66JPushModule.removeReceiveOpenNotificationListener(this.openNotificationListener) 67// JPushModule.removeGetRegistrationIdListener(this.getRegistrationIdListener) 68// console.log(\'Will clear all notifications\') 69// JPushModule.clearAllNotifications() 70} 71 72 } 73 74 ...

(2),在极光官网上推送
React Native之通知栏消息提示(android)

文章图片

React Native之通知栏消息提示(android)

文章图片

 
3.2,实现的效果
React Native之通知栏消息提示(android)

文章图片
 
 
问题:
1,真机没接收到通知
解决:打开node_modules/jpush_react-native/android/src/AndroidManifest.xml,将所有的${applicationId}替换成你的包名。或将project/android/src/AndroidManifest.xml,的${applicationId}替换成你的包名。
...< application android:name=".MainApplication" android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme"> < activity android:name=".MainActivity" android:configChanges="keyboard|keyboardHidden|orientation|screenSize" android:label="@string/app_name"> < intent-filter> < action android:name="android.intent.action.MAIN" /> < category android:name="android.intent.category.LAUNCHER" /> < /intent-filter> < /activity> ...< !-- Required . Enable it you can get statistics data with channel --> < meta-data android:name="JPUSH_CHANNEL" android:value="https://www.songbingjia.com/android/${APP_CHANNEL}"/> < meta-data android:name="JPUSH_APPKEY" android:value="https://www.songbingjia.com/android/${JPUSH_APPKEY}"/> < /application>

.MainApplication和.MainActivity前添加包名
 

    推荐阅读