美文网首页
Swift_极光推送

Swift_极光推送

作者: YHWXQ简简单单的生活 | 来源:发表于2016-10-31 20:20 被阅读666次

    iOS 平台上推送通知,只有 APNs 这个官方的通道,是可以随时送达的。一般开发者都是自己部署应用服务器向 APNs Server 推送。
    JPush iOS 推送相比直接向 APNs 推送有什么好处呢?

    1. 减少开发及维护成本:
        应用开发者不需要去开发维护自己的推送服务器与 APNs 对接。
        集成了 JPush iOS SDK 后不必自己维护更新 device token。
        通过 JPush 的 Web Portal 直接推送,也可以调用JPush的 HTTP 协议 API 来完成,开发工作量大大减少。
    2. 减少运营成本:
        极光推送支持一次推送,同时向 Android, iOS, WinPhone 三个平台。支持统一的 API 与推送界面。
        极光推送提供标签、别名绑定机制,以及提供了非常细分的用户分群方式,运营起来非常简单、直观。
    3. 提供应用内推送:
        除了使得 APNs 推送更简单,也另外提供应用内消息推送。这在类似于聊天的场景里很有必要。
    

    第一步:在极光官网注册极光推送

    第二步:下载SDK


    资源文件
    包名为JPush-iOS-SDK-{版本号}
       lib文件夹:包含头文件 JPUSHService.h,静态库文件jpush-ios-x.x.x.a ,支持的iOS版本为 6.0 及以上版本。(请注意:模拟器不支持APNs)
       pdf文件:集成指南
       demo文件夹:示例
    

    第三步:创建应用-在 JPush的管理Portal 上创建应用并上传推送(APNs)证书

    Paste_Image.png
    Paste_Image.png
    创建成功后自动生成 AppKey 用以标识该应用
    Paste_Image.png

    第四步:配置工程

    1. 导入SDK

    将SDK包解压,在Xcode中选择“Add files to 'Your project name'...”,将解压后的lib子文件夹(包含JPUSHService.h、jpush-ios-x.x.x.a)添加到你的工程目录中

    Paste_Image.png
    2. 在Build Phases中添加Framework
    CFNetwork.framework
    CoreFoundation.framework
    CoreTelephony.framework
    SystemConfiguration.framework
    CoreGraphics.framework
    Foundation.framework
    UIKit.framework
    Security.framework
    Xcode7需要的是libz.tbd;Xcode7以下版本是libz.dylib
    Adsupport.framework (获取IDFA需要;如果不使用IDFA,请不要添加)
    UserNotifications.framework(Xcode8及以上)
    libresolv.tbd (JPush 2.2.0及以上版本需要)
    
    3. 创建并配置PushConfig.plist文件
    在你的工程中创建一个新的Property List文件,并将其命名为PushConfig.plist,文件所含字段如下:
    1. CHANNEL
    指明应用程序包的下载渠道,为方便分渠道统计,具体值由你自行定义,如:App Store。
    2. APP_KEY
    填写管理Portal上创建应用后自动生成的AppKey值。请确保应用内配置的 AppKey 与第1步在 Portal 上创建应用后生成的 AppKey 一致。
    3. APS_FOR_PRODUCTION
    1.3.1版本新增,用于标识当前应用所使用的APNs证书环境。
    0 (默认值)表示采用的是开发证书,1 表示采用生产证书发布应用。
    注:此字段的值要与Build Settings的Code Signing配置的证书环境一致。
       在1.2.2或之前版本的配置文件中,有 TEST_MODE 这个键,新版的SDK不再使用,可以将它删除。
    
    Paste_Image.png

    第五步:添加代码

    2.1.0版本开始,API类名为JPUSHService,不再使用原先的APService
    
    1. 注册极光
    在桥接文件中导入头文件#import "JPUSHService.h"
    @UIApplicationMain
    class AppDelegate: UIResponder, UIApplicationDelegate, WXApiDelegate {
        var window: UIWindow?
    
        func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
            // 极光推送
            if #available(iOS 8.0, *) {
                let type: UInt = UIUserNotificationType.Badge.rawValue | UIUserNotificationType.Sound.rawValue | UIUserNotificationType.Alert.rawValue
                JPUSHService.registerForRemoteNotificationTypes(type, categories: nil)
            } else {
                let type: UInt = UIUserNotificationType.Badge.rawValue | UIUserNotificationType.Sound.rawValue | UIUserNotificationType.Alert.rawValue
                JPUSHService.registerForRemoteNotificationTypes(type, categories: nil)
            }
            // 参数2: 填你创建的应用生成的AppKey
            // 参数3: 可以不填
            // 参数4: 这个值生产环境为YES,开发环境为NO(BOOL值)
            JPUSHService.setupWithOption(launchOptions, appKey: "62ea209c75aadacd9f863b65", channel: nil, apsForProduction: false)
            return true
        }
    
    2. 注册DeviceToken
    // 注册成功后会调用AppDelegate的下面方法,得到设备的deviceToken
        func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
            JPUSHService.registerDeviceToken(deviceToken)
            print("Notification token: ", deviceToken)
        }
        
        //(App即将进入前台)中将小红点清除
        func applicationWillEnterForeground(application: UIApplication) {    UIApplication.sharedApplication().applicationIconBadgeNumber = 0
        }
        
        // 处理接收推送错误的情况(一般不会…)
        func application(application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: NSError) {
         print("error: Notification setup failed: ", error)
        }
        
        // App在后台时收到推送时的处理
        func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject], fetchCompletionHandler completionHandler: (UIBackgroundFetchResult) -> Void) {
            JPUSHService.handleRemoteNotification(userInfo)
            let alert: String = userInfo["aps"]!["alert"] as! String
            var badge: Int = userInfo["aps"]!["badge"] as! Int
            badge -= 1
            JPUSHService.setBadge(badge)
            UIApplication.sharedApplication().applicationIconBadgeNumber = 0
            /**
             *  iOS的应用程序分为3种状态
             *      1、前台运行的状态UIApplicationStateActive;
             *      2、后台运行的状态UIApplicationStateInactive;
             *      3、app关闭状态UIApplicationStateBackground。
             */        
            // 应用在前台 或者后台开启状态下,不跳转页面,让用户选择。
            if (application.applicationState == UIApplicationState.Active) || (application.applicationState == UIApplicationState.Background){
                UIAlertView(title: "推送消息", message: "\(alert)", delegate: nil, cancelButtonTitle: "确定").show()
            }else{
                //杀死状态下,直接跳转到跳转页面
            }
            // badge清零
            application.applicationIconBadgeNumber = 0
            JPUSHService.resetBadge()
            completionHandler(UIBackgroundFetchResult.NewData)
        }
    

    结果
    运行出现以下信息,表示连接成功

    Paste_Image.png
    发送推送消息
    Paste_Image.png
    极光平台推送测试成功状态
    Paste_Image.png

    相关文章

      网友评论

          本文标题:Swift_极光推送

          本文链接:https://www.haomeiwen.com/subject/tplputtx.html