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é:
et imprimer:
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!
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)
}
}
let str = deviceToken.map { String(format: "%02hhx", $0) }.joined()
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)
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()
}
}
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)
Si vos données sont encodées en base64.
if ( dataObj != nil ) {
let encryptedDataText = dataObj!.base64EncodedString(options: NSData.Base64EncodingOptions())
NSLog("Encrypted with pubkey: %@", encryptedDataText)
}
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()
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é