Я создал приложение для iOS, вызывающее сервер, который принимает вызовы только с IP-адресов из белого списка (требование безопасности клиента).Теперь они установили временное перенаправление 307.Я изменил исходный корневой URL-адрес на новый адрес перенаправления, и теперь я получаю 401 - Ошибки несанкционированного доступа.Ничто другое в коде не изменилось, кроме URL.Я проверил с помощью Почтальона и звонки работают с адресом перенаправления.Кто-нибудь знает, что вызывает эту проблему?Я подозреваю, что заголовок HTTP поврежден и токен носителя потерян где-то в процессе.
Вот ответ HTTP:
<NSHTTPURLResponse: 0x600003315840> { URL: https://"API URL HERE" } { Status Code: 401, Headers {
"Access-Control-Allow-Origin" = (
"*"
);
"Content-Length" = (
0
);
Date = (
"Wed, 06 Mar 2019 13:50:30 GMT"
);
Server = (
""
);
"Www-Authenticate" = (
Bearer
);
"X-XSS-Protection" = (
"1; mode=block"
);
}}
Этофункция вызывающего API:
func callAPI(jsonData: Data, childUrl: String, completionHandler: @escaping (_ success: Bool, _ data: Data, _ response: HTTPURLResponse) -> Void) {
let access_token = cache.access_token
let networkHeaders = [ "Content-Type": "application/json", "Authorization": access_token, "cache-control": "no-cache" ]
print(access_token)
let dataResponse = Data()
let urlResponse = HTTPURLResponse()
guard let url = URL(string: config.rootAPIUrl + childUrl) else { return }
var request = URLRequest(url: url, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0)
request.httpMethod = "POST"
request.httpBody = jsonData
request.allHTTPHeaderFields = networkHeaders
let session = URLSession.shared
session.dataTask(with: request) { data, response, error in
if error != nil {
DispatchQueue.main.async {
completionHandler(false, dataResponse, urlResponse)
}
}
if let response = response as? HTTPURLResponse, let data = data {
DispatchQueue.main.async {
completionHandler(true, data, response)
}
}
}.resume()
}