web-dev-qa-db-fra.com

swift 3.0 Données en chaîne?

func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {}

Je veux deviceToken to string

mais:

let str = String.init(data: deviceToken, encoding: .utf8)

str est nil

Swift 3.0

comment puis-je laisser data à string?

Enregistrement pour les notifications Push dans Xcode 8/Swift 3.0? ne fonctionne pas et la réponse est il y a quelques mois, je l'avais essayé:

enter image description here

et imprimer:

enter image description here

79
weijia.wang

Je suis venu chercher la réponse à la question Swift 3 Données vers chaîne et je n'ai jamais eu de bonne réponse. Après quelques bêtises, j'ai trouvé ceci:

var testString = "This is a test string"
var somedata = testString.data(using: String.Encoding.utf8)
var backToString = String(data: somedata!, encoding: String.Encoding.utf8) as String!
141
4redwings

voici mon extension de données. ajoutez ceci et vous pourrez appeler data.ToString ()

import Foundation

extension Data
{
    func toString() -> String?
    {
        return String(data: self, encoding: .utf8)
    }
}
29
luhuiya
let str = deviceToken.map { String(format: "%02hhx", $0) }.joined()
14
Hogdotmac

J'ai trouvé le moyen de le faire. Vous devez convertir Data en NSData:

let characterSet = CharacterSet(charactersIn: "<>")
let nsdataStr = NSData.init(data: deviceToken)
let deviceStr = nsdataStr.description.trimmingCharacters(in: characterSet).replacingOccurrences(of: " ", with: "")
print(deviceStr)
8
weijia.wang

C’est beaucoup plus facile dans Swift 3 et versions ultérieures avec réduction:

func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
    let token = deviceToken.reduce("") { $0 + String(format: "%02x", $1) }

    DispatchQueue.global(qos: .background).async { 
        let url = URL(string: "https://example.com/myApp/apns.php")!

        var request = URLRequest(url: url)
        request.addValue("application/json", forHTTPHeaderField: "Content-Type")
        request.httpMethod = "POST"
        request.httpBody = try! JSONSerialization.data(withJSONObject: [
            "token" : token, 
            "ios" : UIDevice.current.systemVersion,
            "languages" : Locale.preferredLanguages.joined(separator: ", ")
            ])

        URLSession.shared.dataTask(with: request).resume()
    }
}
2
Gargoyle

Swift 4 version de la réponse de 4redwings:

let testString = "This is a test string"
let somedata = testString.data(using: String.Encoding.utf8)
let backToString = String(data: somedata!, encoding: String.Encoding.utf8)
1
Abhishek Jain

Si vos données sont encodées en base64.

if ( dataObj != nil ) {
    let encryptedDataText = dataObj!.base64EncodedString(options: NSData.Base64EncodingOptions())
    NSLog("Encrypted with pubkey: %@", encryptedDataText)
}
0
jeet.chanchawat

Pour prolonger la réponse de weijia.wang:

extension Data {
    func hexString() -> String {
        let nsdataStr = NSData.init(data: self)
        return nsdataStr.description.trimmingCharacters(in: CharacterSet(charactersIn: "<>")).replacingOccurrences(of: " ", with: "")
    }
}

utilisez-le avec deviceToken.hexString()

0
Markus

Selon Apple document officiel, le jeton de périphérique ne peut pas être décodé. Donc, je pense que la meilleure chose à faire est de laisser les choses en place.

LIEN: https://developer.Apple.com/library/content/documentation/NetworkingInternet/Conceptual/RemoteNotificationsPG/APNSOverview.html dans la section Architecture de sécurité

enter image description here

0
Kyle Bing