zoukankan      html  css  js  c++  java
  • React Native之通知栏消息提示(ios)

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

    一,需求分析与概述

    详情请查看:React Native之通知栏消息提示(android)

    二,极光推送注册与集成

    2.1,注册

    详情请查看:React Native之通知栏消息提示(android)

    2.2,集成(ios)

    第一步:安装

    打开终端,进入项目根目录文件夹下,执行以下命令:

    1  npm install jpush-react-native --save
    2  jpush-react-native 1.4.2 版本以后需要同时安装 jcore-react-native
    3  npm install jcore-react-native --save 

    第二步:配置

    自动关联配置

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

    执行完 link 项目后可能会出现报错,这没关系,打开Xcode手动配置一下 

    手动配置

    (1),检查Libraries文件夹下有没有RCTJpushModule.xcodprojRCTJcoreModule.xcodproj文件,没有的话就添加文件,目录在项目文件夹下的:

    1 /node_modules/jpush-react-native/ios/RCTJPushModule.xcodeproj
    2 /node_modules/jcore-react-native/ios/RCTJCoreModule.xcodeproj

     

    (2),在 iOS 工程 targets 的 General->Link Binary with Libraries 中加入如下库:

     1 libRCTJpushModule.a
     2 libRCTJcoreModule.a
     3 libz.tbd
     4 CoreTelephony.framework
     5 Security.framework
     6 CFNetwork.framework
     7 CoreFoundation.framework
     8 SystemConfiguration.framework
     9 Foundation.framework
    10 UIKit.framework
    11 UserNotifications.framework
    12 libresolv.tbd

    (3),在AppDelegate.h文件里边添加如下代码:

    1 static NSString *appKey = @"";     //填写appkey
    2 static NSString *channel = @"nil";    //填写channel   一般为nil
    3 static BOOL isProduction = false;  //填写isProdurion  平时测试时为false ,生产时填写true

    (4),在AppDelegate.m文件里边添加如下代码:

     1 /**
     2  * Copyright (c) 2015-present, Facebook, Inc.
     3  *声明部分
     4  */
     5 #import <RCTJPushModule.h>
     6 #ifdef NSFoundationVersionNumber_iOS_9_x_Max
     7 #import <UserNotifications/UserNotifications.h>
     8 #endif
     9 @implementation AppDelegate
    10 
    11 
    12 /**
    13  * Copyright (c) 2015-present, Facebook, Inc.
    14  *功能模块部分
    15  */
    16 - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
    17 {
    18   [JPUSHService registerDeviceToken:deviceToken];
    19 }

    为了在收到推送点击进入应用程序能够获取该条件推送内容需要在AppDelegate.mdidReceiveRemoteNotification方法里面添加[[NSNotificationCenter defaultCenter] postNotificationName:kJPFDidReceiveRemoteNotification object:userInfo]方法

    注意:这里需要在两个方法里面加一个是iOS7以前的一个是iOS7及以后的,如果AppDelegate.m没有这个两个方法则直接复制这两个方法,在iOS10的设备则可以使用JPush提供的两个方法

     1 - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
     2 {
     3   [[NSNotificationCenter defaultCenter] postNotificationName:kJPFDidReceiveRemoteNotification object:userInfo];
     4 }
     5 //iOS 7 Remote Notification
     6 - (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
     7 {
     8   [[NSNotificationCenter defaultCenter] postNotificationName:kJPFDidReceiveRemoteNotification object: notification.userInfo];
     9 }
    10 // iOS 10 Support
    11 - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)   (UIBackgroundFetchResult))completionHandler
    12 {
    13   [[NSNotificationCenter defaultCenter] postNotificationName:kJPFDidReceiveRemoteNotification object:userInfo];
    14 }
    15 - (void)jpushNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(NSInteger))completionHandler
    16 {
    17   NSDictionary * userInfo = notification.request.content.userInfo;
    18   if ([notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
    19     [JPUSHService handleRemoteNotification:userInfo];
    20     [[NSNotificationCenter defaultCenter] postNotificationName:kJPFDidReceiveRemoteNotification object:userInfo];
    21   }
    22 
    23   completionHandler(UNNotificationPresentationOptionAlert);
    24 }

    在 didFinishLaunchingWithOptions方法里面添加如下代码:

    1 JPUSHRegisterEntity * entity = [[JPUSHRegisterEntity alloc] init];
    2   entity.types = UNAuthorizationOptionAlert|UNAuthorizationOptionBadge|UNAuthorizationOptionSound;
    3   [JPUSHService registerForRemoteNotificationConfig:entity delegate:self];
    4   [JPUSHService setupWithOption:launchOptions appKey:appKey channel:channel apsForProduction:isProduction];

    (5),#import <RCTJPushModule.h>可能会报找不到的错误,需要在Build Settings->Search Paths->Header Search Paths添加代码:

    1 $(SRCROOT)/../node_modules/jpush-react-native/ios/RCTJPushModule

    (6),在Capabilities中点开推送Push Notifications以及Background Modes中的Remote notifications

     

    ios的推送证书申请可参考:react native极光推送android和ios证书申请

    这样就基本完成了所有的配置。接下来就可以在 JS 中调用插件提供的 API 了。

    三,使用与实现

    3.1,使用

    (1),在js中 1 import React, { PureComponent } from 'react';

     2 import {
     3   Linking,
     4   Alert
     5 } from 'react-native';
     6 import JPushModule from 'jpush-react-native'
     7 
     8 ...
     9 
    10 
    11 componentDidMount() { 
    12 /****************************通知 start **************************************************/
    13     if (Platform.OS === 'android') {
    14       JPushModule.initPush()
    15    // 新版本必需写回调函数
    16       JPushModule.notifyJSDidLoad(resultCode => {
    17         if (resultCode === 0) {
    18         }
    19       })
    20     } else {
    21       JPushModule.setupPush()
    22     }
    23     // 接收自定义消息
    24     this.receiveCustomMsgListener = map => {
    25       this.setState({
    26         pushMsg: map.content
    27       })
    28       console.log('extras: ' + map.extras)
    29     }
    30 
    31         // 接收自定义消息JPushModule.addReceiveCustomMsgListener(this.receiveCustomMsgListener)
    32     this.receiveNotificationListener = map => {
    33       console.log('alertContent: ' + map.alertContent)
    34       console.log('extras: ' + map.extras)
    35     }
    36     // 接收推送通知
    37 JPushModule.addReceiveNotificationListener(this.receiveNotificationListener)
    38  // 打开通知
    39     this.openNotificationListener = map => {
    40       // console.log('Opening notification!')
    41     //  console.log('map.extra: ' + map.extras)
    42      let webUrl= JSON.parse(map.extras).webUrl
    43       let url = webUrl.replace(new RegExp("/", 'g'), "/")
    44       Linking.canOpenURL(url).then(supported => {
    45         if (!supported) {
    46           Alert.alert('您的系统不支持打开浏览器!')
    47         } else {
    48           return Linking.openURL(url);
    49         }
    50       }).catch(err => { });
    51 
    52     }
    53     JPushModule.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   }
    63   componentWillUnmount() {
    64     JPushModule.removeReceiveCustomMsgListener(this.receiveCustomMsgListener)
    65     JPushModule.removeReceiveNotificationListener(this.receiveNotificationListener)
    66     JPushModule.removeReceiveOpenNotificationListener(this.openNotificationListener)
    67     // JPushModule.removeGetRegistrationIdListener(this.getRegistrationIdListener)
    68     // console.log('Will clear all notifications')
    69     // JPushModule.clearAllNotifications()
    70   }
    71   
    72 }
    73 
    74 ...

    ios不支持的函数:

    setBaseStyle () {
        if (Platform.OS === 'android') {
          JPushModule.setStyleBasic()
        } else {
          Alert.alert('iOS not support this function', '')
        }
      }
    
      setCustomStyle () {
        if (Platform.OS === 'android') {
          JPushModule.setStyleCustom()
        } else {
          Alert.alert('iOS not support this function', '')
        }
    

      

    (2),在极光官网上设置与推送

       

     

  • 相关阅读:
    搭建一个Flv视频播放服务器
    nginx 搭建http协议拖动播放 FLV 视频播放服务器
    轻轻松松干掉flash右键菜单方法
    在Eclipse中配置tomcat7.0
    js中cookie的使用详细分析
    windows 版Tomcat 7.0的配置
    FMS服务器录制权限的开放NetStream.Record.NoAccess错误解决方法
    WCF入门(四)——会话与实例
    WCF selfhost测试
    WCF 消息队列通信
  • 原文地址:https://www.cnblogs.com/jackson-yqj/p/9928050.html
Copyright © 2011-2022 走看看