注意:
NSNotificationCenter:通知中心:用来注册通知事件(需要先注册才能监听通知)。
UILocalNotification:本地通知,进行UI通知(iOS8以后也需要先注册通知授权
)。
这两个类不在同一个框架中:
NSNotificationCenter在Foundation框架中
UILocalNotification在UIKit框架中
本地推送
iOS7:不需要授权
iOS8:以后需要授权
步骤:
1、通过在AppDelegate中判断版本注册通知授权
2、在需要的界面创建一个本地通知,设置通知的属性,最后又AppDelegate调用通知
在#import "AppDelegate.h"中
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
>
if ([[UIDevice currentDevice].systemVersion doubleValue] >= 8.0) {
UIUserNotificationSettings *userNotification = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert categories:nil ];
[application registerUserNotificationSettings:userNotification];
}
return YES;
}
>
在#import "ViewController.h"中
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
// 1.创建本地通知
UILocalNotification *localNote = [[UILocalNotification alloc] init];
>
// 2.设置本地通知的内容
// 2.1.设置通知发出的时间
localNote.fireDate = [NSDate dateWithTimeIntervalSinceNow:3.0];
// 2.2.设置通知的内容
localNote.alertBody = @"通知内容";
// 2.3.设置滑块的文字
localNote.alertAction = @"滑块文字";
// 2.4.决定alertAction是否生效
localNote.hasAction = NO;
// 2.5.设置点击通知的启动图片
localNote.alertLaunchImage = @"随便都可以";
// 2.6.设置alertTitle
localNote.alertTitle = @"123";
// 2.7.设置有通知时的音效
localNote.soundName = @"语音文件名";
// 2.8.设置应用程序图标右上角的数字
localNote.applicationIconBadgeNumber = 9;
// 2.9.设置额外信息
localNote.userInfo = @{@"type" : @1};
>
// 3.调用通知
[[UIApplication sharedApplication] scheduleLocalNotification:localNote];
}
>
Application代理方法的launchOptions属性
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions ;
launchOptions:用户直接打开程序的时候这个参数是没有值的。
若由其他应用程序通过openURL:启动,则UIApplicationLaunchOptionsURLKey对应的对象为启动URL(NSURL),
UIApplicationLaunchOptionsSourceApplicationKey对应启动的源应用程序的bundle ID (NSString);
若由本地通知启动,则UIApplicationLaunchOptionsLocalNotificationKey对应的是为启动应用程序的的本地通知对象(UILocalNotification);
若由远程通知启动,则UIApplicationLaunchOptionsRemoteNotificationKey对应的是启动应用程序的的远程通知信息userInfo(NSDictionary);
根据通知跳转到相应的界面
1、在AppDelegate中实现方法监听通知,判断是否进入后台,根据通知设置的额外信息userInfo来打开相应的界面。
// 应用程序在进入前台,或者在前台的时候都会执行该方法
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
{
// 针对应用程序在后台的时候进行的跳转
if (application.applicationState == UIApplicationStateInactive) {
NSLog(@"进行界面的跳转");
NSLog(@"%@", notification.userInfo);
>
UIView *redView = [[UIView alloc] init];
redView.frame = CGRectMake(0, 0, 100, 100);
redView.backgroundColor = [UIColor redColor];
[self.window.rootViewController.view addSubview:redView];
}
}
2、当程序被杀死了,当再次点击进来是不会来到实现的代理方法,此时需要在程序加载完毕之后判断。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// 界面的跳转(针对应用程序被杀死的状态下的跳转)
if (launchOptions[UIApplicationLaunchOptionsLocalNotificationKey]) {
// 跳转代码
UILabel *redView = [[UILabel alloc] init];
redView.frame = CGRectMake(0, 0, 200, 300);
redView.numberOfLines = 0;
redView.font = [UIFont systemFontOfSize:12.0];
redView.backgroundColor = [UIColor redColor];
redView.text = [NSString stringWithFormat:@"%@", launchOptions];
[self.window.rootViewController.view addSubview:redView];
}
return YES;
}
远程推送原理 (长链接,还有即使通信)
需要真机,配置证书。
以微信客户端为例
1、客户端将手机的唯一标识UDID和应用程序的唯一标识Bound Identifier发送给苹果的APNs服务器。
2、苹果的APNs服务器根据这两个唯一标识生成一个加密的唯一标识deviceToken,并放回给客服端。
3、在AppDelegate中实现相应的方法拦截,并将这个deviceToken和微信帐号ID发送给客户端的服务器,客户端的服务器保存(deviceToke和微信帐号对应)。
4、当别人需要发送消息给特定的微信帐号好友,微信服务器将对应的帐号的deviceToken和消息发送给苹果的APNs服务器。
5、苹果的APNs服务器根据对应的deviceToken发送推送通知给微信客户端。
6、根据推送的消息,监听用户的点击(类似本地通知)。
代码
#import "AppDelegate.h"
@interface AppDelegate ()
@end
@implementation AppDelegate
>
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
> //但程序被杀死,点击推送通知进入程序来到这,根据不同iOS版本进行通知的授权与注册
if ([[UIDevice currentDevice].systemVersion doubleValue] >= 8.0) { //iOS8
UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeAlert | UIUserNotificationTypeBadge | UIUserNotificationTypeSound categories:nil];
//注册通知授权
[application registerUserNotificationSettings:settings];
//注册通知
[application registerForRemoteNotifications];
} else { // iOS7
[application registerForRemoteNotificationTypes:UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeNewsstandContentAvailability | UIRemoteNotificationTypeSound |UIRemoteNotificationTypeAlert];
}
>
if (launchOptions[UIApplicationLaunchOptionsRemoteNotificationKey]) {
// 跳转
}
return YES;
}
>
//拦截苹果APNs服务器返回的deviceToken
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{
// 将DeviceToken传给服务器
NSLog(@"%@", deviceToken.description);
}
>
//当程序从后台点击推送通知进入时会调用这个方法
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
{
NSLog(@"%@", userInfo);
}
>
//当程序进入后台,不点击推送消息,也会调用这个方法,但是发送的通知有固定的格式,1.需要打开后台模式 2.告诉系统是否有新内容的更新3、需要添加"content-available":"1";
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
{
NSLog(@"11111111");
>
UIView *redView = [[UIView alloc] init];
redView.backgroundColor = [UIColor redColor];
redView.frame = CGRectMake(100, 100, 100, 100);
[self.window.rootViewController.view addSubview:redView];
>
// 1.需要打开后台模式 2.告诉系统是否有新内容的更新 3.发送的通知有固定的格式("content-available":"1")
completionHandler(UIBackgroundFetchResultNewData);
}
设置应用程序右上角显示提示数字的两种方法
方法一: [application setApplicationIconBadgeNumber:2]; (优先级高)
方法二: UILocalNotification *localNote = [[UILocalNotification alloc] init];
localNote.applicationIconBadgeNumber = 9;