简体   繁体   English

Azure + Swift推送通知

[英]Azure + Swift Push Notifications

I am trying to make a VERY simple PUSH from a remote server to an app. 我试图从远程服务器到应用程序进行非常简单的推送。

I have set up a notification hub on Azure as per [1], but I cannot get a debug message down to the device. 我按照[1]在Azure上设置了一个通知中心,但我无法将调试消息发送到设备。 I DO NOT WANT TO READ / WRITE FROM A DB TABLE USING MOBILE SERVICES 我不想使用移动服务从数据库表读取/写入

I am doing this in Swift, and I have found nothing on the internet that actually receives a push from a server is iOS swift as a complete tutorial. 我在Swift中这样做,我在互联网上一无所获 ,实际上从服务器接收推送是iOS swift作为一个完整的教程。

I do not know, for example, how to write the following code in swift: 我不知道,例如,如何在swift中编写以下代码:

- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
    // TODO: update @"MobileServiceUrl" and @"AppKey" placeholders
    MSClient *client = [MSClient clientWithApplicationURLString:@"MobileServiceUrl" applicationKey:@"AppKey"];

    [client.push registerNativeWithDeviceToken:deviceToken tags:@[@"uniqueTag"] completion:^(NSError *error) {
        if (error != nil) {
            NSLog(@"Error registering for notifications: %@", error);
        }
    }];
}

So far this is my code in my AppDelegate (some of the code I got from [2]): 到目前为止,这是我的AppDelegate中的代码(我从[2]得到的一些代码):

    var client: MSClient?

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    if(UIApplication.instancesRespondToSelector(Selector("registerUserNotificationSettings:")))
    {
        application.registerUserNotificationSettings(UIUserNotificationSettings(forTypes: UIUserNotificationType.Sound | UIUserNotificationType.Alert | UIUserNotificationType.Badge, categories: nil))
    }
    /*else
    {
    //do ios7 stuff here. If you are using just local notifications then you dont need to do anything. for remote notifications:
    application.registerForRemoteNotificationTypes(UIUserNotificationType.Sound | UIUserNotificationType.Alert | UIUserNotificationType.Badge)
    }*/

    self.client = MSClient(applicationURLString: "[url]", applicationKey: "[key]")

    UIApplication.sharedApplication().registerForRemoteNotifications()
    let settings = UIUserNotificationSettings(forTypes: .Alert, categories: nil)
    UIApplication.sharedApplication().registerUserNotificationSettings(settings)

    return true
}

func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
    println("Got device token \(deviceToken)");
    //IS THIS EVEN CORRECT???? [3] and [4]
    /*let json = ("{\"platform\":\"ios\", \"deviceToken\":\"\(deviceToken)\"}" as NSString).dataUsingEncoding(NSUTF8StringEncoding)

    self.client?.invokeAPI("register_notifications", data: json, HTTPMethod: "POST", parameters: nil, headers: nil, completion:nil)*/
    let registrationTags: [String] = ["tag"];
    //EDIT 1 - I HAVE MADE A LITTLE PROGRESS
    self.client?.push.registerNativeWithDeviceToken(deviceToken, tags: registrationTags, completion: { (error) -> Void in
        println("Error registering")
    })
}

func application(application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: NSError) {
    println("Could not register \(error)");
}

func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject]) {
    println("Remote notification received!")
    println("Awesome!")
}

I am getting a device token back, which means I should be registered, but I do not know how to properly implement [code] 我收到一个设备令牌,这意味着我应该注册,但我不知道如何正确实现[代码]

self.client?.push.registerNativeWithDeviceToken(deviceToken: deviceToken, tags: registrationTags, completion: [code])

EDIT 1 I have made some progress here: 编辑1我在这里取得了一些进展:

self.client?.push.registerNativeWithDeviceToken(deviceToken, tags: registrationTags, completion: { (error) -> Void in
        println("Error registering")
    })

Now I get an error with registering: 现在我在注册时遇到错误:

Error Domain=com.Microsoft.WindowsAzureMobileServices.ErrorDomain Code=-1302 "Error: Internal Server Error" UserInfo=0x14d97b10 {NSLocalizedDescription=Error: Internal Server Error, com.Microsoft.WindowsAzureMobileServices.ErrorResponseKey= { URL: https://[servicename].azure-mobile.net/push/registrations%3FdeviceId=[longnumber]&platform=apns } { status code: 500, headers { "Cache-Control" = "no-cache"; Error Domain = com.Microsoft.WindowsAzureMobileServices.ErrorDomain Code = -1302“Error:Internal Server Error”UserInfo = 0x14d97b10 {NSLocalizedDescription = Error:Internal Server Error,com.Microsoft.WindowsAzureMobileServices.ErrorResponseKey = {URL: https:// [servicename ] .azure-mobile.net / push / registrations%3FdeviceId = [longnumber]&platform = apns } {status code:500,headers {“Cache-Control”=“no-cache”; "Content-Length" = 51; “内容长度”= 51; "Content-Type" = "application/json"; “Content-Type”=“application / json”; Date = "Thu, 05 Mar 2015 08:52:10 GMT"; Date =“星期四,2015年3月5日08:52:10 GMT”; Server = "Microsoft-IIS/8.0"; Server =“Microsoft-IIS / 8.0”; "Set-Cookie" = "ARRAffinity=[somehash];Path=/;Domain=[servicename].azure-mobile.net"; “Set-Cookie”=“ARRAffinity = [somehash]; Path = /; Domain = [servicename] .azure-mobile.net”; "X-Powered-By" = "ASP.NET"; “X-Powered-By”=“ASP.NET”; "x-zumo-version" = "Zumo.master.0.1.6.4217.Runtime"; “x-zumo-version”=“Zumo.master.0.1.6.4217.Runtime”; } }, com.Microsoft.WindowsAzureMobileServices.ErrorRequestKey= { URL: https://[servicename].azure-mobile.net/push/registrations%3FdeviceId=[longnumber]&platform=apns }} },com.Microsoft.WindowsAzureMobileServices.ErrorRequestKey = {URL: https:// [servicename] .azure-mobile.net / push / registrations%3FdeviceId = [longnumber]&platform = apns }}

EDIT 2 编辑2

I have now made the following changes after reading [5]: 我在阅读[5]后现在做了以下更改:

    func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
        let token = NSString(data: deviceToken, encoding: NSUTF8StringEncoding)
        println("Got device token");        

        let hub = SBNotificationHub(connectionString: CONNECTIONSTRING, notificationHubPath: HUBPATH)
        hub.registerNativeWithDeviceToken(deviceToken, tags: nil, completion: {(error) -> Void in
            println("Error registering: \(error)")
        })
    }

And the output I now see is: 我现在看到的输出是:

Got device token 有设备令牌
Error registering: nil 注册错误:无

I feel like I am making progress but when I send the debug push from Azure I see nothing in my logs (currently when I receive a push I just print a message) 我觉得我正在取得进展但是当我从Azure发送调试推送时,我在日志中看不到任何内容(目前当我收到推送时我只是打印一条消息)

References: 参考文献:
[1] http://azure.microsoft.com/en-us/documentation/articles/notification-hubs-ios-get-started/ [1] http://azure.microsoft.com/en-us/documentation/articles/notification-hubs-ios-get-started/
[2] Registering for iOS 7 notifications in swift [2] 在swift中注册iOS 7通知
[3] https://github.com/Azure/azure-content/blob/master/articles/notification-hubs-ios-mobile-services-register-user-push-notifications.md [3] https://github.com/Azure/azure-content/blob/master/articles/notification-hubs-ios-mobile-services-register-user-push-notifications.md
[4] http://azure.microsoft.com/en-us/documentation/articles/notification-hubs-ios-mobile-services-register-user-push-notifications/ [4] http://azure.microsoft.com/en-us/documentation/articles/notification-hubs-ios-mobile-services-register-user-push-notifications/
[5] http://azure.microsoft.com/en-us/documentation/articles/notification-hubs-ios-get-started/ [5] http://azure.microsoft.com/en-us/documentation/articles/notification-hubs-ios-get-started/

This worked fine for me: 这对我很好:

let client: MSClient = MSClient(applicationURLString: "https://yoururl.azure-mobile.net/", applicationKey: "yourApplicationKey")
client.push.registerNativeWithDeviceToken(deviceToken, tags: nil, completion: {(error) -> Void in

  if error != nil{
    NSLog("Error registering for notifications: %@", error)
  }

})

This one worked for me. 这个对我有用。 Hope this may help. 希望这可能有所帮助。

var client: MSClient?

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    #if !TARGET_IPHONE_SIMULATOR
        let notiType:UIUserNotificationType = .Alert | .Badge | .Sound
        let settings = UIUserNotificationSettings(forTypes: notiType, categories: nil)
        UIApplication.sharedApplication().registerUserNotificationSettings(settings)
        UIApplication.sharedApplication().registerForRemoteNotifications()
    #endif

    self.client = MSClient(applicationURLString:"https://yourAppName.azure-mobile.net/", applicationKey:"yourApplicationKey")
    return true
}

func application(application: UIApplication!, didFailToRegisterForRemoteNotificationsWithError error: NSError!) {
    println("Failed to register with error: \(error)");
}

func application(application: UIApplication!, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData!) {
    let hub = SBNotificationHub(connectionString:"yourConnectionString", notificationHubPath:"yourAppName")
    hub.registerNativeWithDeviceToken(deviceToken, tags:nil, completion: { (error) in
        if (error != nil) {
            println("Error registering for notification: \(error)")
        }
    })
}

func application(application: UIApplication!, didReceiveRemoteNotification userInfo:[NSObject : AnyObject]?, fetchCompletionHandler:()) {
    println("Recived: \(userInfo)")
    NSNotificationCenter.defaultCenter().postNotificationName("ReceivedNotification", object:userInfo)
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM