本地推送-远程推送-极光推送
推送通知:
-
通知的分类:
-
本地推送
-
由app本身给应用程序推送消息,不需要服务器支持
-
应用场景:app定时闹钟,定时提醒等等
-
-
-
远程推送
-
由服务器推送消息给用户,需要服务器支持
-
应用场景:qq/微信消息提醒、淘宝提醒等,支付宝账单提醒等等
-
-
推送的样式:
-
在屏幕顶部显示一块横幅
-
在屏幕中间弹出一个UIAlertView
-
锁屏界面也可以显示
-
收到通知时,同时播放音效
-
收到通知时,改变app图标上的数字
-
一. 本地通知:
1.简介
-
本地通知需要用到一个重要的类是UILocalNotification
-
实现本地通知的步骤:
-
创建本地通知
-
创建本地通知要发送的内容信息
-
发送时间
-
发送内容
-
播放音效
-
-
2. 实现本地通知
2.1注册通知
-
ios8之后,无论想要发出本地通知(不管是本地通知还是远程),首先得先注册.(ios8之前不需要)
-
通常是在didFinishLaunchingWithOptions中进行注册
-
代码如下:
if ([[UIDevice currentDevice].systemVersion doubleValue]>=8.0f) {
UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert categories:nil];
[application registerUserNotificationSettings:settings];
}
2.2创建并且发送通知
- 创建本地通知
//1.创建本地通知
UILocalNotification *localNote = [[UILocalNotification alloc] init];
- 设置本地通知的内容
//2.设置通知显示的内容
//设置通知发出的时间
localNote.fireDate = [NSDate dateWithTimeIntervalSinceNow:5];
//设置通知的内容
localNote.alertBody = @"你是不是啥";
// 是否让上面的文字生效
localNote.hasAction = NO;
// 设置滑块显示的文字
localNote.alertAction = @"快点";
//设置通知中心的标题
localNote.alertTitle = @"哥哥";
// 设置通知的声音
localNote.soundName = @"buyao.wav";
//设置应用程序图标右上角的数字
localNote.applicationIconBadgeNumber = 10;
- 调度通知
// 3.调度通知
[[UIApplication sharedApplication] scheduleLocalNotification:localNote];
3. 监听本地通知的点击
-
3.1 为什么要监听本地通知的点击
-
不管应用程序出于后台还是被杀死,点击通知都可以打开应用程序
-
应用场景。比如: 当用户点击通知时,进入到某一个固定界面
-
-
3.2 如何监听本地通知的点击
-
在前台
- 如果在前台则不需要进入页面跳转
-
在后台
- 点击应用时进行页面跳转
-
被杀死
- 点击应用打开应用时,进行页面的跳转
-
- 该代码为应用程序在前台或者后台时的做法
/*
UIApplicationStateActive,在前台
UIApplicationStateInactive,进入前台
UIApplicationStateBackground 在后台
*/
// 应用在前台时,也会收到该通知,这时不应该进行页面的跳转
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
{
// 跳转到固定的界面
if (application.applicationState == UIApplicationStateInactive) {
// 进行页面的跳转
} else {
// 其他情况不需要跳转
}
}
- 该代码为应用程序被杀死时的做法
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// iOS8注册通知
if ([UIDevice currentDevice].systemVersion.doubleValue >= 8.0) {
UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeAlert | UIUserNotificationTypeSound categories:nil];
[application registerUserNotificationSettings:settings];
}
// 判断是否是通过点击通知打开了应用程序
if (launchOptions[UIApplicationLaunchOptionsLocalNotificationKey]) {
// 跳转代码
}
return YES;
}
二. 远程通知:
概念
-
由服务器发送消息给用户弹出消息的通知(需要联网)
-
远程推送服务:又称APNs(Apple Push Notification Services)
-
为什么公司服务器不是直接推送消息给用户?
-
在通常情况下服务器端是不能主动向客户端推消息的.
-
如果想服务器端给客户端推消息,必须建立长连接
-
客户端在处于后台时不能和服务器端建立长连接
-
-
为什么苹果服务器可以推消息给用户?
-
所有的苹果设备,在联网状态下,都会与苹果的服务器建立长连接
-
苹果建立长连接的作用:
时间校准
系统升级提示
查找我的iPhone
远程通知
...
- 苹果在推送消息时,如何准确的推送给某一个用户,并且知道是哪一个APP
- 在公司服务器把消息给苹果的APNs服务器时,必须告知苹果DeviceToken
- 什么是DeviceToken?
- DeviceToken是由用户手机的UDID和应用程序的BundleID共同生成的
- 通过DeviceToken可以找到唯一手机中的唯一应用程序
- 如何获得DeviceToken?
- 客户端到苹果的APNs注册即可获得
- 什么是DeviceToken?
流程图
如何做远程通知
-
首先,BundleID对用的APPID必须是明确的
-
APPID必须配置两个证书
-
开发证书:用户调试远程推送
-
发布证书:用户发布后给用户推送消息
-
-
根据上面的APPID重新配置描述文件
-
安装对应的证书,即可开始测试远程推送
远程推送证书配置
- 1.登录开发者账号
-
2.添加一个测试证书
2.png -
3.创建一个与项目的BundleID相同的AppID
- 显示Push Notifications幷非Enableed,而是Configurable
- 证书的配置
- 在Certificates中配置证书
- 选择证书的类型(调试和发布都需要配置)
- 下载并安装
-
进入钥匙串,导出p12
16.png
17.png
- 选择Provisioning Profiles中的Development
- 配置项目中的bundleid以及Prosiong Profile
获取DeviceToken
-
在苹果APNs服务器注册,以获取DeviceToken
- 通常在
didFinishLaunchingWithOptions
中添加如下代码进行注册
- 通常在
if ([UIDevice currentDevice].systemVersion.doubleValue >= 8.0) {
// 1.向用户请求可以给用户推送消息
UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert categories:nil];
[application registerUserNotificationSettings:settings];
// 2.注册远程通知(拿到用户的DeviceToken)
[application registerForRemoteNotifications];
} else {
[application registerForRemoteNotificationTypes:UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound];
}
- 注册之后再另外一个代理方法中拿到DeviceToken
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{
// 5e8cf393 9e950137 86ac8375 12185078 19eb3ebd 936777e1 f061caec a48cb236
// 将用户的用户名和deviceToken发送给服务器,让服务器进行保存备份即可
NSLog(@"%@", deviceToken);
}
- 将DeviceToken发送到服务器即可
监听远程通知的点击
1. 为什么要监听
- 业务需求:点击通知之后跳转到某一个界面中去
2. 如何监听
1.状态
-
在前台
- 如果在前台则不需要进入页面跳转
-
在后台
- 点击应用时进行页面跳转
-
被杀死
- 点击应用打开应用时,进行页面的跳转
2. 当应用程序出于后台时的监听
// 和本地通知基本一致,只是这里是接收到远程通知
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
{
// 跳转到固定的界面
if (application.applicationState == UIApplicationStateInactive) {
// 进行页面的跳转
} else {
// 其他情况不需要跳转
}
}
3. 应用程序被杀死时的监听
(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// 判断是否是通过点击通知打开了应用程序
if (launchOptions[UIApplicationLaunchOptionsRemoteNotificationKey]) {
// 跳转代码
}
return YES;
}
三. 极光推送
-
将我们服务器需要做的事情用激光推送服务器作为替代
-
流程图
如何集成
-
进入官网下载极光推送的SDK
-
点击官网上方的文档,里面有集成指南,按照着文档一步一步按部就班就可以了
注意
-
使用极光推送需要新建一个PushConfig.plist文件并添加3个字段
-
在发布应用之前需要把PushConfig.plist文件中的
PS_FOR_PRODUCTION
中的Value字段0
改成1
-
且在官方的应用中需要把开发环境改成ios生产环境
总结
本地推送
与远程推送
的步骤实现其实是差不多的,远程推送无非就是多了一些证书配置,一步一步按着步骤配置就好了。