Примечание: Я использую шаг 2.3 здесь, я работаю над интеграцией Stripe с firebase.
У меня есть следующий охранник, который выйдет из строя. Это не удается из-за json const.
guard let data = data, let json = try? JSONSerialization.jsonObject(with: data, options: []) as? [String : Any], let accountURLString = json["url"] as? String, let accountURL = URL(string: accountURLString) else {
// handle error
print(": jsonfdshkfdbsh :")
return
}
К сожалению, следующее объявление внутри него не работает:
let json = try? JSONSerialization.jsonObject(with: data, options: []) as? [String : Any]
Что не так с линией? Как заставить его работать?
Обновлять: (То, что я пробовал, но нет работал)
let data = data as Data?
print(data, " datavar")//has a value (not nil)
let json = try? JSONSerialization.jsonObject(with: data!, options: []) as? [String : Any]
print(json, " jsonvar") //nil
let accountURLString = json!["url"] as? String
let accountURL = URL(string: accountURLString!)
Обновление 2:
Я задавался вопросом и исследовал, может ли проблема быть в том, что путь переменной request может быть недействительным (?). Однако мое тестирование со значением, которое, как я знаю, существует в базе данных, не дало (сработало) никаких результатов.
if let url = URL(string: backendAPIBaseURL)?.appendingPathComponent("stripe_customers/IYNpofaWUFXfobmFRLMLIEZXxqN2") {// usually the string is: "onboard-user"
var request = URLRequest(url: url)
request.httpMethod = "POST"
print(URLSession.shared.dataTask(with: request), "<-- ay un problem?")
print(request, " this was the request value")
let task = URLSession.shared.dataTask(with: request) { (data, response, error) in
print("does thsi run??? ", data)
let data: Data = data!// as Data?
print(data, " ttekjfdsjklfhdas")
//...
Вы также должны дважды проверить, что ваш JSON действителен. Обычно я рекомендую передать его jsonlint.com. Недействительный JSON выдаст вам эту ошибку. Кроме того, замените try? на try, и система выдаст сообщение об ошибке, сообщающее о проблеме. try? прямо говорит, что вы хотите выбросить все полезные сообщения об ошибках.
Вы уверены, что ваш второй сниппер кода является причиной его сбоя? Причиной могут быть любые последующие предложения в заявлении охраны, если вы не проверяли его индивидуально.
@Rikh Да, индивидуально проверял. Я уверен.





Проблема оказалась связанная с Обновление 2. request был проблемой.
Я закончил менять код на следующий, который работал:
func createStripeConnectAccount(uid: String, completion: @escaping(String?, String?) -> Void) { //accountID, Error
let parameters: [String:Any] = [:]
let url = "https://us-central1-name-fhdskj.cloudfunctions.net/createConnectAccount"
AF.request(url, method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: [:]).responseJSON { response in
switch response.result {
case .success(let dict):
print(dict)
let successDict: [String: Any?] = dict as! [String: Any?]
let body = successDict["body"] as! [String: Any?]
let acctNum = body["success"] as! String
print(acctNum, "<-- link did it twerk?")
completion(acctNum, nil)
case .failure(let error):
print(error.localizedDescription)
completion(nil, error.localizedDescription)
}
}
}
func createAccountLink(accountID: String, completion: @escaping(String?, String?) -> Void) { //url, Error
let parameters: [String:Any] = ["accountID": accountID]
let url = "https://us-central1-name-fdsad.cloudfunctions.net/createStripeAccountLink"
AF.request(url, method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: [:]).responseJSON { response in
switch response.result {
case .success(let dict):
print(dict)
let successDict: [String: Any?] = dict as! [String: Any?]
let body = successDict["body"] as! [String: Any?]
let link = body["success"] as! String
print(link, "<-- link did it twerk?")
completion(link, nil)
case .failure(let error):
print(error.localizedDescription)
completion(nil, error.localizedDescription)
}
}
}
Вам нужно будет интегрировать Alomofire Pod.
Можете ли вы опубликовать ссылку или информацию о данных json, которые нужно проанализировать? JSONSerialization должен работать, но это также зависит от структуры вашего json.