iOS判断网络请求超时的方法_IOS

 本文介绍了iOS判断网络请求超时的方法,代码具体如下:

 + (AFHTTPRequestOperation *)requestOperationWithUrl:(NSString *)url

                    requetMethod:(NSString *)method

                     paramData:(NSDictionary *)aParamData

             constructingBodyWithBlock:(void (^)(id <AFMultipartFormData> formData))block

                      success:(successBlock)success

                      failure:(failureBlock)failure {

AFHTTPRequestSerializer *requestSerializer = [AFJSONRequestSerializer serializer];

  NSMutableURLRequest *request;

  if (block) {

    method = @"POST";

    request = [requestSerializer multipartFormRequestWithMethod:method URLString:url parameters:aParamData constructingBodyWithBlock:block error:nil];

  }else{

    request = [requestSerializer requestWithMethod:method URLString:url parameters:aParamData error:nil];

  }

 AFHTTPRequestOperation *op = [[AFHTTPRequestOperation alloc] initWithRequest:request];

  AFJSONResponseSerializer *responseSerializer = [AFJSONResponseSerializer serializer];

  responseSerializer.removesKeysWithNullValues = YES;

  responseSerializer.acceptableContentTypes = [NSSet setWithObject:@"text/html"];

  op.responseSerializer = responseSerializer;

 __weak AFHTTPRequestOperation *weakOp = op;

  [op setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {

    if ([responseObject[@"code"] integerValue] == 0) {

      if (success) {

//        success(weakOp, aParamData, responseObject[@"list"]);

        success(weakOp, aParamData, responseObject);

      }

    }else{

      NSLog(@"operation error msg = [%@]", responseObject[@"description"]);

      if (failure) {

        failure(weakOp, aParamData, [self errorWithRet:responseObject]);

      }

    }

  } failure:^(AFHTTPRequestOperation *operation, NSError *error) {

    NSLog(@"operation failed = [%@] error = [%@]", operation, error);

    if (failure) {

      failure(weakOp, aParamData, error);

    }    

  }];  

  return op;

}

打印 error

Error Domain=NSURLErrorDomain Code=-1001 "请求超时。"

UserInfo={

NSErrorFailingURLStringKey=http://123.56.109.92/refitcar/service.s?sn=, _kCFStreamErrorCodeKey=-2102, NSErrorFailingURLKey=http://123.56.109.92/refitcar/service.s?sn=, NSLocalizedDescription=请求超时。, _kCFStreamErrorDomainKey=4, 

NSUnderlyingError=0x167da8e0 {

Error Domain=kCFErrorDomainCFNetwork Code=-1001 "请求超时。" 

UserInfo={

_kCFStreamErrorCodeKey=-2102, 

NSErrorFailingURLStringKey=http://123.56.109.92/refitcar/service.s?sn=, 

NSErrorFailingURLKey=http://123.56.109.92/refitcar/service.s?sn=,

 NSLocalizedDescription=请求超时。, 

_kCFStreamErrorDomainKey=4

}
}

}

可见:

po error.localizedDescription  请求超时。

po error.code  -1001

po error.userInfo

{

  NSErrorFailingURLKey = "http://123.56.109.92/refitcar/service.s?sn=";

  NSErrorFailingURLStringKey = "http://123.56.109.92/refitcar/service.s?sn=";

  NSLocalizedDescription = "\U8bf7\U6c42\U8d85\U65f6\U3002";

  NSUnderlyingError = "Error Domain=kCFErrorDomainCFNetwork Code=-1001 \"\U8bf7\U6c42\U8d85\U65f6\U3002\" UserInfo={_kCFStreamErrorCodeKey=-2102, NSErrorFailingURLStringKey=http://123.56.109.92/refitcar/service.s?sn=, NSErrorFailingURLKey=http://123.56.109.92/refitcar/service.s?sn=, NSLocalizedDescription=\U8bf7\U6c42\U8d85\U65f6\U3002, _kCFStreamErrorDomainKey=4}";

  "_kCFStreamErrorCodeKey" = "-2102";

  "_kCFStreamErrorDomainKey" = 4;

}

所以使用 error.code是否等于   -1001  判断请求超时

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ios
, ios请求超时处理
ios网络请求超时
ios 请求超时判断、ios 判断网络请求超时、js 判断ajax请求超时、afn请求超时判断、js判断http请求超时,以便于您获取更多的相关知识。

时间: 2024-10-25 10:09:28

iOS判断网络请求超时的方法_IOS的相关文章

iOS开发中不合法的网络请求地址如何解决_IOS

NSString *const kWebsite = @http://image.baidu.com/search/index?tn=baiduimage&ipn=r&ct=201326592&cl=2&lm=-1&st=-1&fr=&sf=1&fmq=1459502303089_R&pv=&ic=0&nc=1&z=&se=1&showtab=0&fb=0&width=&

关于Android网络请求超时处理

问题描述 关于Android网络请求超时处理 一个请求10秒后无响应怎么做处理,我想在超时后调用缓存数据,但是不知道怎么判断网络超时,项目用了afinal,没找到超时后的处理方法,只有onsuccess和onfailed方法 解决方案 Android Volley网络请求Android使用Volley请求网络Android 异步网络请求及协调CountDownLatch 解决方案二: // 1.设置超时时间 conn.setConnectTimeout(5000);// 设置连接超时时间 //

iOS 异步网络请求 和 把 同步网络请求放在子线程有什么区别?

问题描述 iOS 异步网络请求 和 把 同步网络请求放在子线程有什么区别? iOS 异步网络请求 和 把 同步网络请求放在子线程有什么区别? 解决方案 那就是异步和同步的问题咯,,异步的话是不会等待请求完成能继续执行下面的程序,,而同步会等待请求的完成,在继续执行下面的 解决方案二: 同步放子线程效果跟异步达到的类似.只是一个是API原生支持,一个是你自己代码来实现 解决方案三: 同步放子线程效果跟异步达到的类似.只是一个是API原生支持,一个是你自己代码来实现 解决方案四: 同步放子线程效果跟

android 网络请求库volley方法详解_Android

使用volley进行网络请求:需先将volley包导入androidstudio中 File下的Project Structrue,点加号导包   volley网络请求步骤:       1. 创建请求队列       RequestQueue queue = Volley.newRequestQueue(this);       2.创建请求对象(3种)                            StringRequest request = new StringRequest("

android 网络请求库volley方法详解

使用volley进行网络请求:需先将volley包导入androidstudio中 File下的Project Structrue,点加号导包 volley网络请求步骤: 1. 创建请求队列       RequestQueue queue = Volley.newRequestQueue(this); 2.创建请求对象(3种) StringRequest request = new StringRequest("请求方法","请求的网络地址","成功的网

iOS - ASIHTTPRequest 网络请求

前言 使用 iOS SDK 中的 HTTP 网络请求 API,相当的复杂,调用很繁琐,ASIHTTPRequest 就是一个对 CFNetwork API 进行了封装,并且使用起来非常简单的一套 API,外号 "HTTP终结者",用 Objective-C 编写,运行效率很高,可以很好的应用在 Mac OS X 系统和 iOS 平台的应用程序中,ASIHTTPRequest 适用于基本的 HTTP 请求,和基于 REST 的服务之间的交互.可惜作者早已停止更新,有一些潜在的 BUG 无

iOS - AFNetworking 网络请求

前言 在 iOS 开发中,一般情况下,简单的向某个 Web 站点简单的页面提交请求并获取服务器的响应,用 Xcode 自带的 NSURLConnection 是能胜任的.但是,在绝大部分下我们所需要访问的 Web 页面则是属于那种受到权限保护的页面,并不是有一个简单的 URL 可以访问的.这就涉及到了 Session 和 Cookie 的处理了,在此时使用 NSURLConnection 也是能够达到要求的,只是其中处理起来的复杂度和难度就提升了.为了更好的处理向 Web 站点的请求,包括处理

iOS - NSURLConnection 网络请求

前言 @interface NSURLConnection : NSObject class NSURLConnection : NSObject DEPRECATED: The NSURLConnection class should no longer be used. NSURLSession is the replacement for NSURLConnection 从 iOS 9 开始 NSURLConnection 的大部分方法被废弃. 1.NSURLConnection NSUR

iOS - Alamofire 网络请求

前言 Alamofire 是 Swift 语言的 HTTP 网络开发工具包,相当于 Swift 实现 AFNetworking 版本.当然,AFNetworking 非常稳定,在 Mac OSX 与 iOS 中也能像其他 Objective-C 代码一样用 Swift 编写.不过 Alamofire 更适合 Swift 语言风格习惯(Alamofire 与 AFNetworking 可以共存一个项目中,互不影响).Alamofire 取名来源于 Alamo Fire flower. Alamof