【Warming】:AFNetworking 奇葩问题旨在针对奇葩问题提出奇葩的解法,部分验证并在实际中用到,但不保证有隐性问题。
大家应该都遇到过这样一个问题,在app中某一个请求是需要发生在登录之后的,那这个时候有两种思路,1、全局保存并判断用户的登录状态然后继续请求;2、先请求然后根据后台返回的状态判断是否需要进行登录操作,如果需要登录的时候则默默后台登录或者前台弹出登陆页面,登录之后也有两种处理方式,a、让用户手动刷新页面,重新请求数据,b、自动继续请求当前页面的数据,本文主要针对的就是第二种需要用户登录之后继续请求数据的情况
第一种,后台一般保存session或者token都是有时限性的,比如30分钟或者1天等等,这个时候需要每一次登录维持一个计时器在本地,或者每一次请求的时候根据当前请求的时间减去上次的时间,如果大于限定值,则进行重登录操作。我没做过测试,感觉有点麻烦。
第二种,对请求之后的结果进行处理,然后通过block回调,再处理原接口,代码如下:
+ (void)requestWithMethod:(NSString*)method
urlString:(NSString*)urlString
parameters:(id)paramters
result:(void(^)(NSDictionary * responseObject, NSDictionary * errorDic))result{
[[NetworkClient client] requestWithMethod:method
urlString:urlString
parameters:paramters
success:^(NSURLSessionDataTask *task, id responseObject) {
NSString * rcode = responseObject[@"rcode"];
if (rcode.integerValue == 0) { // 处理成功的情况
result(responseObject[@"data"], nil);
}else if (rcode.integerValue == SPErrorTokenAvalid){ // 处理登录失效的情况
[SPUserOperationManager neeLoginWithBlock:^{
[self requestWithMethod:method
urlString:urlString
parameters:paramters
result:result];
}];
}else{
result(nil, responseObject);
[SPErrorManager showErrorMessageWithErrorDic:responseObject];
}
} fail:^(NSURLSessionDataTask *task, NSError *error) {
DLog(@"error==>%@",error.localizedDescription);
[SPErrorManager showErrorMessageWithContent:error.localizedDescription];
}];
}
至此,大功告成!赶快去试一下吧!