func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {}
Je veux deviceToken
enchaîner
mais:
let str = String.init(data: deviceToken, encoding: .utf8)
str
est nil
Swift 3.0
comment puis - je laisser data
à string
?
Vous vous inscrivez aux 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 imprimez:
file -I /path/to/file.txt
. Sinon convertir en utilisant iconv:iconv -f UTF-16LE -t UTF-8 /path/to/file.txt > /path/to/utf8/file.txt
Réponses:
Je suis venu chercher la réponse à la question Swift 3 Data to String et je n'ai jamais obtenu de bonne réponse. Après quelques bêtises, je suis venu avec 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!
la source
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data)
.Je ne sais pas pourquoi?voici mon extension de données. ajoutez ceci et vous pouvez appeler data.ToString ()
import Foundation extension Data { func toString() -> String? { return String(data: self, encoding: .utf8) } }
la source
let str = deviceToken.map { String(format: "%02hhx", $0) }.joined()
la source
J'ai trouvé le moyen de le faire. Vous devez convertir
Data
enNSData
:let characterSet = CharacterSet(charactersIn: "<>") let nsdataStr = NSData.init(data: deviceToken) let deviceStr = nsdataStr.description.trimmingCharacters(in: characterSet).replacingOccurrences(of: " ", with: "") print(deviceStr)
la source
C'est beaucoup plus facile dans Swift 3 et versions ultérieures en utilisant réduire:
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() } }
la source
Version Swift 4 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)
la source
Vous pouvez également utiliser
let data = String(decoding: myStr, as: UTF8.self)
ici une ressource sur la conversion de données en chaînela source
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()
la source
Si vos données sont encodées en base64.
if ( dataObj != nil ) { let encryptedDataText = dataObj!.base64EncodedString(options: NSData.Base64EncodingOptions()) NSLog("Encrypted with pubkey: %@", encryptedDataText) }
la source
Selon la documentation Apple ci-dessous, le jeton d'appareil ne peut pas être décodé. Donc, je pense que la meilleure chose à faire est de laisser les choses en place.
la source
let urlString = baseURL + currency if let url = URL(string: urlString){ let session = URLSession(configuration: .default) let task = session.dataTask(with: url){ (data, reponse, error) in if error != nil{ print(error) return } let dataString = String(data: data!, encoding: .utf8) print(dataString) } task.resume() }
la source
pour swift 5
let testString = "This is a test string" let somedata = testString.data(using: String.Encoding.utf8) let backToString = String(data: somedata!, encoding: String.Encoding.utf8) as String? print("testString > \(testString)") //testString > This is a test string print("somedata > \(String(describing: somedata))") //somedata > Optional(21 bytes) print("backToString > \(String(describing: backToString))") //backToString > Optional("This is a test string")
la source