iOS - 百度推送
2016-05-06 15:29
369 查看
在很多项目开发中,大家都做过推送!例如:极光推送、信鸽推送、个推等等一系列的推送。我们使用的都是集成过后的SDK,其原理都是相同的。
这里我们来做一下百度推送。
审核通过后下载SDK,创建应用(上传相应的推送证书格式看要求到出),默认创建的应用是,开发者测试的,上线后要改成生产的。
![](http://img.blog.csdn.net/20160506144030181)
2)相应的库是否导入
![](http://img.blog.csdn.net/20160506144814183)
3)证书要带推送功能
2)点击推送消息
3)注册推送服务
4)收到推送消息时
其他的跳转页面等操作可以预判所存放状态status.
其他的具体内容各个推送都有自己具体的详细文档,说明的要比我写的详尽的多,如有什么不对不懂得地方可以评论,我会及时解答和修改!
这里我们来做一下百度推送。
1.百度推送
1.1 百度账号的注册申请和审核
登录百度云推送:http://push.baidu.com/fc。填写相关资料、审核。审核通过后下载SDK,创建应用(上传相应的推送证书格式看要求到出),默认创建的应用是,开发者测试的,上线后要改成生产的。
1.2 SDK的导入与配置
1)所使用的SDK很简单。(里面有个测试音频text.caf)2)相应的库是否导入
3)证书要带推送功能
1.3 SDK在项目中的使用
1)启动时写的- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { //***********************关于如何设置badge角标加1的方法*********************** /* 服务端推送的badge是几就会显示几,你只需要跟服务端同步消息数目,然后让服务端自己,该推送几,就推送几,比如你应用打开的时候,或者进入后台的时候跟服务端同步,这个点,需要你们自己去设计,应用没有消息的时候,服务端推送了1,当应用打开时候,告诉服务端,app没点击通知,那下次应用推送2,依次类推。 */
// iOS8 下需要使用新的 API if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 8.0) { UIUserNotificationType myTypes = UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert; UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:myTypes categories:nil]; [[UIApplication sharedApplication] registerUserNotificationSettings:settings]; }else { UIRemoteNotificationType myTypes = UIRemoteNotificationTypeBadge|UIRemoteNotificationTypeAlert|UIRemoteNotificationTypeSound; [[UIApplication sharedApplication] registerForRemoteNotificationTypes:myTypes]; } #warning 测试 开发环境 时需要修改BPushMode为BPushModeDevelopment 需要修改Apikey为自己的Apikey // 在 App 启动时注册百度云推送服务,需要提供 Apikey [BPush registerChannel:launchOptions apiKey:@"Apikey改成自己的" pushMode:BPushModeDevelopment withFirstAction:nil withSecondAction:nil withCategory:nil isDebug:YES]; // App 是用户点击推送消息启动 NSDictionary *userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]; if (userInfo) { NSLog(@"从消息启动:%@",userInfo); [BPush handleNotification:userInfo]; } //角标清0 [[UIApplication sharedApplication] setApplicationIconBadgeNumber:0]; }
2)点击推送消息
// 此方法是 用户点击了通知,应用在前台 或者开启后台并且应用在后台 时调起 - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler { completionHandler(UIBackgroundFetchResultNewData); NSLog(@"********** iOS7.0之后 background **********"); // 应用在前台 或者后台开启状态下,不跳转页面,让用户选择。 if (application.applicationState == UIApplicationStateActive || application.applicationState == UIApplicationStateBackground) { NSLog(@"acitve or background"); UIAlertView *alertView =[[UIAlertView alloc]initWithTitle:@"收到一条消息" message:userInfo[@"aps"][@"alert"] delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil]; [alertView show]; } else//杀死状态下,直接跳转到跳转页面。 { //这里实现页面跳转 } }
3)注册推送服务
// 在 iOS8 系统中,还需要添加这个方法。通过新的 API 注册推送服务 - (void)application:(UIApplication *)application didRegisterUserNotificationSettings:(UIUserNotificationSettings *)notificationSettings { [application registerForRemoteNotifications]; } - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken { NSLog(@"test:%@",deviceToken); [BPush registerDeviceToken:deviceToken]; [BPush bindChannelWithCompleteHandler:^(id result, NSError *error) { // 需要在绑定成功后进行 settag listtag deletetag unbind 操作否则会失败 if (result) { [BPush setTag:@"Mytag" withCompleteHandler:^(id result, NSError *error) { if (result) { NSLog(@"设置tag成功"); } }]; } }]; } // 当 DeviceToken 获取失败时,系统会回调此方法 - (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error { NSLog(@"DeviceToken 获取失败,原因:%@",error); }
4)收到推送消息时
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo { // App 收到推送的通知 [BPush handleNotification:userInfo]; NSLog(@"********** ios7.0之前 **********"); // 应用在前台 或者后台开启状态下,不跳转页面,让用户选择。 if (application.applicationState == UIApplicationStateActive || application.applicationState == UIApplicationStateBackground) { NSLog(@"acitve or background"); UIAlertView *alertView =[[UIAlertView alloc]initWithTitle:@"收到一条消息" message:userInfo[@"aps"][@"alert"] delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil]; [alertView show]; } else//杀死状态下,直接跳转到跳转页面。 { } } - (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification { NSLog(@"接收本地通知啦!!!"); [BPush showLocalNotificationAtFront:notification identifierKey:nil]; }
1.4 开启和关闭推送按钮
说说我的思路和做法:本地存一个参数1或者0 ,例如:status用于存放状态。加一个按钮,点击关闭状态status存放0,同时UIUserNotificationType设置为:UIUserNotificationTypeNone UIRemoteNotificationType设置为:UIRemoteNotificationTypeNone 反之设置回声音、徽章、弹窗提醒。其他的跳转页面等操作可以预判所存放状态status.
其他的具体内容各个推送都有自己具体的详细文档,说明的要比我写的详尽的多,如有什么不对不懂得地方可以评论,我会及时解答和修改!
相关文章推荐
- iOS 奔溃整理
- iOS Socket 打字节流相关
- iOS 9.0更新碰到:第三方库不包含bitcode
- iOS 开发,调用打电话,发短信,打开网址
- iOS开发系列--音频播放、录音、视频播放、拍照、视频录制
- iOS上传语音、文字、图片
- iOS 沙盒机制
- iOS 中的可遍数组NSMutableArray
- iOS开发系列-线程问题
- IOS开发: NSDictionary *infoDictionary = [[NSBundle mainBundle] infoDictionary]
- 如何用 Instruments 检测 iOS 每个进程的电量消耗?
- iOS滑动解锁、滑动获取验证码效果的实现代码
- iOS自动处理键盘事件的第三方库:IQKeyboardManager
- iOS的几种后台机制
- IOS CopyPNGFile 异常问题解决
- iOS开发系列-动画绘图CALayer
- iOS 关于已配对设备重新检测连接问题
- iOS开发系列--打造自己的“美图秀秀”
- iOS开发-进阶:语言国际化及代码切换语言
- iOS开发_修改系统cell的图像会变模糊的处理