ios – Alamofire:如何在全球范围内处理401?

ios – Alamofire:如何在全球范围内处理401?,第1张

概述我正在尝试构建一个管理我的项目的网络调用的类.到目前为止,我的意思是在全球范围内处理错误,一切都很好.我创建了两个函数;对于post请求postRequest(:_)和get请求getRequests(:_). Datamaker用于返回数据,如URL,参数,标题等,数据解析器函数用于解析响应数据,最后用于解决称为errorHandler()的错误的函数. 当我调用请求函数时,我给出一个参数来帮助 我正在尝试构建一个管理我的项目的网络调用的类.到目前为止,我的意思是在全球范围内处理错误,一切都很好.我创建了两个函数;对于post请求postRequest(:_)和get请求getRequests(:_). Datamaker用于返回数据,如URL,参数,标题等,数据解析器函数用于解析响应数据,最后用于解决称为errorHandler()的错误的函数.

当我调用请求函数时,我给出一个参数来帮助它应该做出哪个请求.在函数中,它首先调用数据制作者获取数据,然后使用Alamofire发出请求,最后如果请求成功,则调用dataparser和onSuccess(data :)闭包,如果不是,则调用errorHandler(statusCode :)和onFailure(消息:)关闭.

我在errorHandler中放了一个switch块,并为其参数提供了statusCode.在401的情况下,我调用了Token().refresh()并在其中完成了名为errorHanlder的完成.在postRequest / errorHandler的完成块中,我使用相同的参数再次调用postRequest.它没用.我不知道为什么,它每次都进入无限循环并连续提出请求.

所以我决定尝试cnoon的AuthorizationManager类(可以在这个链接中找到; Alamofire : How to handle errors globally).我稍微改了一下(添加了一个新的参数作为标题,并将NetworkSuccessHandler的类型更改为NSData).这是新表格:

public class AuthorizationManager: Manager {    public typealias NetworkSuccessHandler = (NSData?) -> VoID    public typealias NetworkFailureHandler = (NShttpURLResponse?,AnyObject?,NSError) -> VoID    private typealias CachedTask = (NShttpURLResponse?,NSError?) -> VoID    private var cachedTasks = Array<CachedTask>()    private var isRefreshing = false    public func startRequest(        method method: Alamofire.Method,URLString: URLStringConvertible,parameters: [String: AnyObject]?,enCoding: ParameterEnCoding,headers: [String:String]?,success: NetworkSuccessHandler?,failure: NetworkFailureHandler?) -> Request?        {            let cachedTask: CachedTask = { [weak self] URLResponse,data,error in                guard let strongSelf = self else { return }                if let error = error {                    failure?(URLResponse,error)                } else {                    strongSelf.startRequest(                        method: method,URLString: URLString,parameters: parameters,enCoding: enCoding,headers:  headers,success: success,failure: failure                    )                }            }            if self.isRefreshing {                self.cachedTasks.append(cachedTask)                return nil            }            // Append your auth tokens here to your parameters            let request = self.request(method,URLString,headers:  headers)            request.response { [weak self] request,response,error in                guard let strongSelf = self else { return }                if let response = response where response.statusCode == 401 {                    strongSelf.cachedTasks.append(cachedTask)                    strongSelf.refreshTokens()                    return                }                if let error = error {                    failure?(response,error)                } else {                    success?(data)                }            }            return request    }    func refreshTokens() {        self.isRefreshing = true            // Make the refresh call and run the following in the success closure to restart the cached tasks        Token().refresh { () -> () in            let cachedTaskcopy = self.cachedTasks            self.cachedTasks.removeAll()            cachedTaskcopy.map { 
func postRequest(requestType: postRequestType,additionalParameters: [String]?,onSuccess: onSuccessRequest = {_ in },onFailure: onFailureRequest = {_ in }){    print("post")    let requestData = returnStaticdataForPostRequest(requestType,additionalParameters: additionalParameters)    let Manager = AuthorizationManager()    Manager.startRequest(method: .POST,URLString: requestData.0,parameters: requestData.2,enCoding: requestData.3,headers: requestData.1,success: { (data) -> VoID in        print("Manager")        let Json = JsON(data: data!)        print(Json)        dataParserForPostRequests(Json,parseForWhat: requestType)        onSuccess(Json: Json)        }) { (response,message,error) -> VoID in            print(error)    }}
(nil,nil,nil) } self.isRefreshing = false } }}

在我的postRequest中调用它,如:

postRequest(.LOGIN,additionalParameters: ["asdasd","asdasd"],onSuccess: { (Json) -> () in            print(">>>login_try_succeeded")                    self.performSegueWithIDentifIEr("LoginToMain",sender: self)            }) { (errorCode) -> () in            print(">>>login_try_Failed(\(errorCode))")        }

并在VIEwController中使用postRequests:

post

这是目前的状态.当我运行代码并尝试登录AuthorizationManager不起作用.它只是打印;

cachedTaskcopy.map { 
AuthorizationManager().startRequest(method: .POST,URLString: NSURL(string: "http://server.url/token")!,parameters: ["":""],enCoding: .JsON,headers: ["":""],success: { (data) -> VoID in            print(data)            }) { (response,error) -> VoID in                print(error)                print("asdasd")        }
(nil,nil) }

最后,我不知道它是否相关,但此行有黄色警告:

public class AuthorizationManager: Manager {    static let shared = AuthorizationManager()    // ...the rest of your class}

说“调用’地图’的结果未使用”

总结一下,我需要弄清楚如何处理401,我知道如何以不同的方式使用AuthorizationManager.

编辑:

我尝试直接从VIEwController运行此代码,但它根本不起作用.这就像代码是不可见的.

AuthorizationManager.shared.startRequest(method: .POST,...etc...
解决方法 可能是您的AuthorizationManager在最初尝试发送请求后没有持久化的情况.

通常,避免使用单例模式是一种好习惯,但这不是一个不好的情况:

在调用您的请求时,请使用此单例实例,而不是实例化新的AuthorizationManager

我猜这可能是个问题,因为在这两种情况下创建AuthorizationManager时都没有主动保留该对象.可以创建管理器,运行请求,然后在cachedTask之前或甚至在完成处理之前解除分配,在这种情况下,你的后卫让strongSelf = self else {return}只返回而不运行任何完成或cachedTasks.

希望这会有所帮助.如果这是问题,那么单例解决方案应该非常简单.

总结

以上是内存溢出为你收集整理的ios – Alamofire:如何在全球范围内处理401?全部内容,希望文章能够帮你解决ios – Alamofire:如何在全球范围内处理401?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1104637.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-28
下一篇 2022-05-28

发表评论

登录后才能评论

评论列表(0条)

保存