Быстрое случайное 400 ошибок при создании URLRequest - PullRequest
0 голосов
/ 28 мая 2018

Я пытаюсь взаимодействовать с API.Служба обычно работает и возвращает ответ 200, но иногда отвечает ошибкой 400 и только пустыми заголовками в описании отладки.Я сделал рекурсивную функцию, чтобы попытаться передать тот же запрос, и я получаю 200 ответов в течение 1-3 попыток, даже если я делаю тот же запрос.Я делал запросы через Postman и PHP и никогда не сталкивался с этой проблемой при взаимодействии с API.Только при отправке запросов в Swift.

    func process(table: String, path: String, objectId: String? = nil, pendingWriteId: String? = nil, method: ApiMethod, processData: [String: Any] = [:], filter: [String: Any] = [:], initializing: Bool = false, remove: Bool = false, completion: @escaping (Error?, JSON) -> Void) {
                var timestamp: Int = Int(Date().timeIntervalSince1970)

                let session = URLSession.shared
                        let url : String = "\(apiURL)\(path)"

                    var params: [String:Any] = [:]

                    if method != .GET {
                        params["data"] = processData
                        params["filter"] = filter
                        params["timestamp"] = timestamp
                    }

                    if method == .DELETE {
                        params["remove"] = remove
                    }

                    let request = NSMutableURLRequest(url: NSURL(string: url)! as URL)
                    request.httpMethod = method.rawValue

                    if let token = auth.authToken {
                        request.setValue(token, forHTTPHeaderField: "token")
                    }

                    print(url)
                    self.sendRequest(session: session, request: request, params: params, pendingWriteId: pendingWriteId, initializing: initializing) { (error, json) in
                        completion(error, json)
                        return
                    }
        }

        func sendRequest(session: URLSession, request: NSMutableURLRequest, params: [String:Any], pendingWriteId: String?, initializing: Bool, completion: @escaping (Error?, JSON) -> Void) {
            do{
                request.httpBody = try JSONSerialization.data(withJSONObject: params, options: [JSONSerialization.WritingOptions.prettyPrinted])

                _ = session.dataTask(with: request as URLRequest as URLRequest, completionHandler: {(data, response, error) in
                    DispatchQueue.main.async {
                        if let response = response {
                            let nsHTTPResponse = response as! HTTPURLResponse
                            let statusCode = nsHTTPResponse.statusCode
                            if statusCode == 200 {
                                if let d = data {
                                    do {
                                        let json = try JSON(data: d)
                                        print(json)
                                        completion(error, json)
                                        return
                                    } catch {
                                        completion(error, JSON())
                                        return
                                    }
                                }
                            } else {
                                print ("\(request.url) status code = \(statusCode)")
                                print(nsHTTPResponse.description)
                                self.sendRequest(session: session, request: request, params: params, pendingWriteId: pendingWriteId, initializing: initializing) { (error, json) in
                                    completion(error, json)
                                    return
                                }
                            }
                        } else {
                            completion(error, JSON())
                            return
                        }
                    }
                }).resume()
            }catch _ {
                print ("Oops something happened")
                completion(ApiError.willNotResolve, JSON())
                return
            }
        }

1 Ответ

0 голосов
/ 28 мая 2018

После почти дня попыток выяснить это я решил проблему за считанные минуты после публикации вопроса.Проблема заключалась в том, что я пытался кодировать JSON пустой набор параметров.Я изменил

request.httpBody = try JSONSerialization.data(withJSONObject: params, options: [JSONSerialization.WritingOptions.prettyPrinted])

на

if params.count > 0 {
       request.httpBody = try JSONSerialization.data(withJSONObject: params, options: [JSONSerialization.WritingOptions.prettyPrinted])
}

и теперь он работает как положено

...