我正在使用 AFNetworking 并且我正在覆盖 -dataTaskWithRequest:completionHandler:
以基本上 MITM 我的请求并在调用实际响应 block 之前进行一些错误处理。但是,我需要在截获的完成处理程序中访问 -dataTaskWithRequest:completionHandler:
方法创建的 NSURLSessionDataTask 对象。所以我对该方法的重写如下所示:
-(NSURLSessionDataTask *)dataTaskWithRequest:(NSURLRequest *)request completionHandler:(void (^)(NSURLResponse *, id, NSError *))completionHandler {
void (^interceptedCompletionHandler)(NSURLResponse *, id, NSError *) = ^void(NSURLResponse * response, id responseObject, NSError * error) {
if (error) {
// Do custom stuff here that needs to use task.taskIdentifier
}
// Then call the original completion handler
completionHandler(response, responseObject, error);
}
return [super dataTaskWithRequest:request completionHandler:interceptedCompletionHandler];
}
这可能吗?
我知道 AFNetworking 可以很容易地添加它,因为完成处理程序的响应参数在 AFURLSessionManager
中设置为 task.response
,它是包含-URLSession:task:didCompleteWithError:
调用完成处理程序。
最佳答案
我想通了。通过声明 block 内联并将 super 调用分配给一个变量,我能够使用生成的任务对象:
-(NSURLSessionDataTask *)dataTaskWithRequest:(NSURLRequest *)request completionHandler:(void (^)(NSURLResponse *, id, NSError *))completionHandler {
__block NSURLSessionDataTask* task = [super dataTaskWithRequest:request completionHandler:
^void(NSURLResponse * response, id responseObject, NSError * error)
{
// I can use task here
if (error) {
// Do custom stuff here that needs to use task.taskIdentifier
}
// Then call the original completion handler
completionHandler(response, responseObject, error);
}
return task;
}
关于ios - 在拦截的完成处理程序中获取 NSURLSessionDataTask,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27800587/