轻松搞定iOS本地消息推送

首先,我们先要明白一个概念,这里的本地通知是UILocalNotification类,和系统的NSNotificationCenter通知中心是完全不同的概念。

一、我们可以通过本地通知做什么

通知,实际上是由IOS系统管理的一个功能,比如某些后台应用做了某项活动需要我们处理、已经退出的应用在某个时间提醒我们唤起等等,如果注册了通知,系统都会在通知触发时给我们发送消息。由此,我们可以通过系统给我们的APP添加通知用户的功能,并且应用非常广泛。例如,闹种类应用,有按时签到相似功能的应用。下面,我们就来介绍如何注册并且设置一个本地通知。

二、了解UILocalNotification类

顾名思义,这个类就是我们需要使用的本地通知类,先来看它的几个属性:

设置系统发送通知的时间(如果是过去的时间或者0,则会立刻发起通知)

@property(nonatomic,copy) NSDate *fireDate;

设置时间的时区

@property(nonatomic,copy) NSTimeZone *timeZone;

设置周期性通知

@property(nonatomic) NSCalendarUnit repeatInterval;

NSCalendarUnit对象是枚举,设定通知的周期

typedef NS_OPTIONS(NSUInteger, NSCalendarUnit) {
 NSCalendarUnitEra  = kCFCalendarUnitEra,
 NSCalendarUnitYear  = kCFCalendarUnitYear,
 NSCalendarUnitMonth  = kCFCalendarUnitMonth,
 NSCalendarUnitDay  = kCFCalendarUnitDay,
 NSCalendarUnitHour  = kCFCalendarUnitHour,
 NSCalendarUnitMinute  = kCFCalendarUnitMinute,
 NSCalendarUnitSecond  = kCFCalendarUnitSecond,
 NSCalendarUnitWeekday  = kCFCalendarUnitWeekday,
 NSCalendarUnitWeekdayOrdinal = kCFCalendarUnitWeekdayOrdinal,
 }

设置周期性通知参照的日历表

@property(nonatomic,copy) NSCalendar *repeatCalendar;

下面这两个函数是IOS8的新功能,在用户进去或者离开某一区域时发送通知

@property(nonatomic,copy) CLRegion *region;

设置区域检测通知是否重复(如果为YES,则没次进去出来都会发送,否则只发送一次)

@property(nonatomic,assign) BOOL regionTriggersOnce;

设置通知的主体内容

@property(nonatomic,copy) NSString *alertBody;

是否隐藏滑动启动按钮

@property(nonatomic) BOOL hasAction;

设置滑动打开的提示文字

@property(nonatomic,copy) NSString *alertAction;

设置点击通知后启动的启动图片

@property(nonatomic,copy) NSString *alertLaunchImage;

下面这个方法是IOS8的新方法,是iwatch的接口,通知的短标题

@property(nonatomic,copy) NSString *alertTitle;

收到通知时,播放的系统音

@property(nonatomic,copy) NSString *soundName;

设置应用程序Icon头标数字

@property(nonatomic) NSInteger applicationIconBadgeNumber;

用户字典,可用于传递通知消息参数

@property(nonatomic,copy) NSDictionary *userInfo;

注意:这个字符串是系统默认的提示音

NSString *const UILocalNotificationDefaultSoundName;

三、本地通知的设计流程

首先,想让我们的APP实现本地通知功能,必须得到用户的授权,在Appdelegate中实现如下代码:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
 // Override point for customization after application launch.
 //如果已经得到授权,就直接添加本地通知,否则申请询问授权
 if ([[UIApplication sharedApplication]currentUserNotificationSettings].types!=UIUserNotificationTypeNone) {
 [self addLocalNotification];
 }else{
 [[UIApplication sharedApplication]registerUserNotificationSettings:[UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeAlert|UIUserNotificationTypeBadge|UIUserNotificationTypeSound categories:nil]];
 }
 return YES;
}

当用户点击允许或者不允许后,会执行如下代理方法,我们把处理逻辑在其中实现

-(void)application:(UIApplication *)application didRegisterUserNotificationSettings:(UIUserNotificationSettings *)notificationSettings{
 if (notificationSettings.types!=UIUserNotificationTypeNone) {
 [self addLocalNotification];
 }
}

添加本地通知的方法:

-(void)addLocalNotification{
 //定义本地通知对象
 UILocalNotification *notification=[[UILocalNotification alloc]init];
 //设置调用时间
 notification.fireDate=[NSDate dateWithTimeIntervalSinceNow:0];//立即触发
 //设置通知属性
 notification.alertBody=@"HELLO,我是本地通知哦!"; //通知主体
 notification.applicationIconBadgeNumber=1;//应用程序图标右上角显示的消息数
 notification.alertAction=@"打开应用"; //待机界面的滑动动作提示
 notification.soundName=UILocalNotificationDefaultSoundName;//收到通知时播放的声音,默认消息声音
 //调用通知
 [[UIApplication sharedApplication] scheduleLocalNotification:notification];
}

实现了上面三个步骤,本地通知的发出和接受基本都已完成,还有一些细节我们需要考虑:

应用进入前台后,将Icon上的头标清除:

-(void)applicationWillEnterForeground:(UIApplication *)application{
 [[UIApplication sharedApplication]setApplicationIconBadgeNumber:0];//进入前台取消应用消息图标
}

当不再需要这个通知时,清除它

[[UIApplication sharedApplication] cancelAllLocalNotifications];

四、获取通知中的用户参数字典

在上面,我们提到了一个参数

@property(nonatomic,copy) NSDictionary *userInfo;

我们可以在注册通知时将这个参数设置,然后在收到通知时使用get方法得到,但是这里有两种情况:

1、如果我们的APP在前台或者后台进入前台时

代码如下:

-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification;

这个方法是APP在前台或者后台收到通知进入前台时调用的方法

2、如果我们的APP在关闭状态

如果是这种情况,我们只能从下面函数的launchOptions中取到我们想要的参数

代码如下:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions;

代码示例如下:

 //接收通知参数
 UILocalNotification *notification=[launchOptions valueForKey:UIApplicationLaunchOptionsLocalNotificationKey];
 NSDictionary *userInfo= notification.userInfo;

本文已被整理到了《iOS推送教程》,欢迎大家学习阅读。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • iOS 点击推送消息跳到应用指定页面的实例

    iOS 点击推送消息跳到应用指定页面 现在的推送用的越来越频繁,几乎每个应用都开始用到了.其实又有几个用户会去看推送消息呢?没办法,产品经理最大啊,只是苦了我们这一帮程序员啊!闲话少说,进入正题.兄弟我用的是极光推送,自然是以极光推送为例了.   现在点击推送消息,有两种跳转方式:1.打开应用,跳转到应用首页:2.打开应用,跳转到指定页面. ​第一种,你什么都不用设置,只要注册极光应用就可以.这里就不写怎么注册极光应用了,可以参考官方文档,写的很详细. ​ 第二种,重头戏来了. // APP未运

  • iOS自定义推送消息提示框

    看到标题你可能会觉得奇怪 推送消息提示框不是系统自己弹出来的吗? 为什么还要自己自定义呢? 因为项目需求是这样的:最近需要做 远程推送通知 和一个客服系统 包括店铺客服和官方客服两个模块 如果有新的消息推送的时候 如果用户当前不在客服界面的时候  要求无论是在app前台 还是app退到后台 顶部都要弹出系统的那种消息提示框 这样的需求 我们就只能自定义一个在app内 弹出消息提示框 实现步骤如下: 1.我们自定义一个view 为 STPushView 推送消息的提示框view  #import

  • 解析iOS10中的极光推送消息的适配

    iOS10发布后,发现项目中的极光推送接收消息异常了. 查了相关资料后才发现,iOS10中对于通知做了不少改变.同时也发现极光也很快更新了对应的SDK. 现在就把适配修改的做法分享一下,希望对有需要的童鞋有所帮助. 具体做法如下: 注意:必须先安装Xcode8.0版本. 一.添加相关的SKD,或framework文件 1.添加UserNotification.framework 2.更新jpush的SDK(最新版本:jpush-ios-2.1.9.a)https://www.jiguang.cn

  • iOS点击推送消息跳转处理

    当用户通过点击通知消息进入应用时 - (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions launchOptions 中会有推送消息的userInfo信息,此时我们可以通过 NSDictionary* remoteNotification = [launchOptions objectForKey:UIApplicationLaunchOp

  • iOS点击推送消息跳到应用指定页面方法

    现在的推送用的越来越频繁,几乎每个应用都开始用到了.其实又有几个用户会去看推送消息呢?没办法,产品经理最大啊,只是苦了我们这一帮程序员啊!闲话少说,进入正题.兄弟我用的是极光推送,自然是以极光推送为例了. 现在点击推送消息,有两种跳转方式:1.打开应用,跳转到应用首页:2.打开应用,跳转到指定页面. ​第一种,你什么都不用设置,只要注册极光应用就可以.这里就不写怎么注册极光应用了,可以参考官方文档,写的很详细. 第二种,重头戏来了. // APP未运行时获取通知的内容 remoteNotific

  • iOS10添加本地推送(Local Notification)实例

    前言 iOS 10 中废弃了 UILocalNotification ( UIKit Framework ) 这个类,采用了全新的 UserNotifications Framework 来推送通知,从此推送通知也有了自己的标签 UN (这待遇真是没别人了),以及对推送功能的一系列增强改进(两个 extension 和 界面的体验优化),简直是苹果的亲儿子,因此推送这部分功能也成为开发中的重点. 本文主要查看了 iOS 10 的相关文档,整理出了在 iOS 10 下的本地推送通知,由于都是代码,

  • iOS10 推送完整剖析和注意事项

    本文旨在对 iOS 推送进行一个完整的剖析,如果你之前对推送一无所知,那么在你认真地阅读了全文后必将变成一个推送老手,你将会对其中的各种细节和原理有充分的理解.以下是 pikacode 使用 iOS 推送的一些经验,欢迎互相交流,指出错漏之处. 推送服务可以说是所有 App 的标配,不论是哪种类型的 App,推送都从很大程度上决定了 App 的 打开率.使用率.存活率 .因此,熟知并掌握推送原理及方法,对每一个开发者来说都是必备技能,对每一个依赖 App 的公司来说都至关重要. 从 iOS 10

  • 轻松搞定iOS本地消息推送

    首先,我们先要明白一个概念,这里的本地通知是UILocalNotification类,和系统的NSNotificationCenter通知中心是完全不同的概念. 一.我们可以通过本地通知做什么 通知,实际上是由IOS系统管理的一个功能,比如某些后台应用做了某项活动需要我们处理.已经退出的应用在某个时间提醒我们唤起等等,如果注册了通知,系统都会在通知触发时给我们发送消息.由此,我们可以通过系统给我们的APP添加通知用户的功能,并且应用非常广泛.例如,闹种类应用,有按时签到相似功能的应用.下面,我们

  • 轻松搞定iOS远程消息推送

    一.引言 IOS中消息的推送有两种方式,分别是本地推送和远程推送,本地推送在http://www.jb51.net/article/93602.htm这篇博客中有详细的介绍,这里主要讨论远程推送的流程与配置过程. 二.远程推送机制的原理 1.从一张很火的图说起 搜索IOS远程推送,你总能看到一张如下的流程示意图,因为这张图确实很火,所以我也将它引用在此: 这张图示意的很清晰,大致意思是这样:你的应用服务端将消息发送到apple的APNS服务器,APNS服务器将消息推送到指定的Iphone,最后由

  • iOS实现消息推送及原理分析

    一.消息推送原理: 在实现消息推送之前先提及几个于推送相关概念,如下图1-1: 1.Provider:就是为指定IOS设备应用程序提供Push的服务器,(如果IOS设备的应用程序是客户端的话,那么Provider可以理解为服务端[消息的发起者]): 2.APNS:Apple Push Notification Service[苹果消息推送服务器]: 3.iPhone:用来接收APNS下发下来的消息: 4.Client App:IOS设备上的应用程序,用来接收iphone传递APNS下发的消息到制

  • flutter消息推送客户端集成方案详解

    目录 一.背景 二.第三方消息推送——个推 1.简介 2.注册开通 3.自定义消息推送——透传 三.项目集成 1.个推客户端flutter插件 2.Android和IOS配置 1)Android 2) iOS 3.通知栏插件flutter_local_notifications 4.个推消息与通知栏整合 最后 一.背景 公司一个CRM APP项目是用Flutter写的,根据业务要求,需要集成消息推送功能.所谓的消息推送就是系统会根据某些行为自动推送信息,手机的通知栏会接收到信息,点击可以打开ap

  • iOS Remote Notification远程消息推送处理

    远程消息推送处理场景有三种:分别是app还没有运行.app在前台运行以及app在后台运行,下面介绍相关流程及三种场景下处理步骤 1.流程 (1)注册通知 首先是在注册远程消息推送,需要注意的是iOS8及以后的系统中注册方法有所改变(同时证书设置以及push权限也需要开启).这一步的目的是,允许app接收远程消息推送. (2)绑定deviceToken deviceToken相当于设备的一个标识,服务器根据这个标识来进行消息推送. ①当用户同意app接收远程消息推送后,手机会向APNs发起一个请求

  • 详解IOS开发之实现App消息推送(最新)

    好久没有写过博客啦,今天就由本菜鸟给大家做一个简单的IOSApp消息推送教程吧!一切从0开始,包括XCode6, IOS8, 以及苹果开发者中心最新如何注册应用,申请证书以及下载配置概要文件,相信很多刚开始接触iOS的人会很想了解一下.(ps:网上看了一下虽然有很多讲述推送的好教程,我也是看着一步步学会的,但是这些教程的时间都是去年或者更早时期的,对引导新手来说不是很合适) 第一部分 首先第一步当然是介绍一下苹果的推送机制(APNS)咯(ps:其实每一篇教程都有),先来看一张苹果官方对其推送做出

  • iOS消息推送原理及具体实现代码

    一.消息推送原理 在实现消息推送之前先提及几个于推送相关概念,如下图1-1: 1.Provider:就是为指定IOS设备应用程序提供Push的服务器,(如果IOS设备的应用程序是客户端的话,那么Provider可以理解为服务端[消息的发起者]): 2.APNS:Apple Push Notification Service[苹果消息推送服务器]: 3.iPhone:用来接收APNS下发下来的消息: 4.Client App:IOS设备上的应用程序,用来接收iphone传递APNS下发的消息到制定

  • iOS开发检测是否开启定位、是否允许消息推送等权限的实例

    1.iOS开发检测是否开启定位: 需要导入: #import <CoreLocation/CoreLocation.h> 代码如下: + (void)openLocationServiceWithBlock:(ReturnBlock)returnBlock { BOOL isOPen = NO; if ([CLLocationManager locationServicesEnabled] && [CLLocationManager authorizationStatus] !

随机推荐