Where can I store the iOS device token for later use?

Now I get the device token through didRegisterForRemoteNotificationsWithDeviceToken. However, I need to use the device token later in my application after my login.

How can I access the deviceToken from another place in the application later, and if I cannot, how / where can I save it to didRegisterForRemoteNotificationsWithDeviceToken, so I can get it later?

+1
source share
2 answers

The easiest way is to use NSUserDefaults

Preservation:

NSUserDefaults * ud = [NSUserDefaults standardUserDefaults];
[ud setObject:myPushToken forKey:@"currentPushToken"];
[ud synchronize];

Recovery:

NSString * currentPushToken = [[NSUserDefaults standardUserDefaults] objectForKey:@"currentPushToken"];
+2
source

Better to use keychainfor such data.

funcs

import UIKit
import Security
class Keychain {

  class func save(key: String, data: NSData) -> Bool {
    let query = [
        kSecClass as String       : kSecClassGenericPassword as String,
        kSecAttrAccount as String : key,
        kSecValueData as String   : data ]

    SecItemDelete(query as CFDictionaryRef)

    let status: OSStatus = SecItemAdd(query as CFDictionaryRef, nil)

    return status == noErr
  }

  class func load(key: String) -> NSData? {
    let query = [
        kSecClass as String       : kSecClassGenericPassword,
        kSecAttrAccount as String : key,
        kSecReturnData as String  : kCFBooleanTrue,
        kSecMatchLimit as String  : kSecMatchLimitOne ]

    var dataTypeRef :Unmanaged<AnyObject>?

    let status: OSStatus = SecItemCopyMatching(query, &dataTypeRef)

    if status == noErr {
        return (dataTypeRef!.takeRetainedValue() as NSData)
    } else {
        return nil
    }
  }

  class func delete(key: String) -> Bool {
    let query = [
        kSecClass as String       : kSecClassGenericPassword,
        kSecAttrAccount as String : key ]

    let status: OSStatus = SecItemDelete(query as CFDictionaryRef)
    return status == noErr
  }

  class func clear() -> Bool {
    let query = [ kSecClass as String : kSecClassGenericPassword ]
    let status: OSStatus = SecItemDelete(query as CFDictionaryRef)   
    return status == noErr
  }
}

( , )

if let data = pass.dataUsingEncoding(NSUTF8StringEncoding,allowLossyConversion: false)  {
  let saveSuccess = Keychain.save("Password", data: data)
}

data = Keychain.load("Password") 
var pass =NSString(data: data, encoding: UInt())
+2

All Articles