【发布时间】:2017-11-23 08:00:41
【问题描述】:
我正在使用 URL 后台会话将 pdf 作为数据流上传,使用 ios 版本 > 9.0。我将超时间隔设置为 300 秒。它根本不工作。 10 秒后出现超时错误。
下面给出一段代码
NSTimeInterval reqTimeInterval = 300.0f;
- (NSURLSession *)uploadSessionForMrNo:(NSString *)mrNo
userRoleId:(NSString *)userRoleId
timestamp:(NSString *)timestamp {
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
queue.maxConcurrentOperationCount = 4;
NSString *backgroundSessionIdentifier = [NSString stringWithFormat:@"backgroundPdfUploadIdentifier_%@",mrNo];
NSURLSessionConfiguration *backgroundSession = [NSURLSessionConfiguration backgroundSessionConfigurationWithIdentifier:backgroundSessionIdentifier];
backgroundSession.discretionary = true;
NSURLSession *session = [NSURLSession sessionWithConfiguration:backgroundSession delegate:self delegateQueue:queue];
[session setAccessibilityLabel:mrNo];
[session setAccessibilityValue:userRoleId];
[session setAccessibilityHint:timestamp];
return session;
}
- (void)uploadPdfRequest:(NSURLRequest *)request
forMrNo:(NSString *)mrNo
userRoleId:(NSString *)userRoleId
andTimestamp:(NSString *)timestamp {
NSURLSession *session = [self uploadSessionForMrNo:mrNo userRoleId:userRoleId timestamp:timestamp];
NSURLSessionDataTask *postDataTask = [session dataTaskWithRequest:request];
NSLog(@"postDataTask %@ timeout %f",postDataTask,request.timeoutInterval);
[postDataTask resume];
}
请求上传数据流。
NSMutableURLRequest *request = [[NSURLRequest requestForPDFStringUpload:uploadQueue.uploadData] mutableCopy];
[request setValue:[DataExchange authToken] forHTTPHeaderField:FBENCRYPT_TOKEN_KEY];
[request setCachePolicy:NSURLRequestUseProtocolCachePolicy];
[request setTimeoutInterval:reqTimeInterval];
[self uploadPdfRequest:request forMrNo:uploadQueue.mrNo userRoleId:uploadQueue.userRoleId andTimestamp:uploadQueue.timestamp];
委托
- (void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task
didCompleteWithError:(NSError *)error {
if (error) {
// Handle error
NSLog(@"Error %@",error);
}
[session finishTasksAndInvalidate];
self.receivedData = nil;
}
如果互联网工作正常,则正常,否则 10 秒后我得到
Error Error Domain=NSURLErrorDomain Code=-1001 "请求超时。" UserInfo={NSErrorFailingURLStringKey=http://test.mydomain.com/common.svc/json/FileUploadPDF, NSErrorFailingURLKey=http://test.mydomain.com/common.svc/json/FileUploadPDF, _kCFStreamErrorDomainKey=4, _kCFStreamErrorCodeKey=-2104, NSLocalizedDescription=请求超时。}
有关此问题的更多详细信息,
我在 ios 9.3 模拟器 中检查了我的代码,它等待连接出现。然后继续上传。我已经检查了它等待它工作的 4 分钟。但是当我将此代码运行到 ios 11.0.1 时,它会在 10 秒后超时。我应该做些什么来实现它。我也试过了
if ([backgroundSession respondsToSelector:@selector(setWaitsForConnectivity:)]) {
[backgroundSession setWaitsForConnectivity:true];
}
但它没有效果。
您可以使用下面的演示文件:-
【问题讨论】:
-
您可以将超时直接传递给您的会话配置,例如
session.timeoutIntervalForRequest = 30.0; session.timeoutIntervalForResource = 60.0; -
已经尝试过 backgroundSession.timeoutIntervalForRequest = 300.0f; backgroundSession.timeoutIntervalForResource = 300.0f;
-
根据我的想法超时与互联网连接不可用没有任何关系,因为超时应该只在互联网正常工作并且平均时间请求无法完成时才有效!!
-
您可以检查可率性,在连接丢失事件中,您可以使用恢复数据暂停您的请求,并在一切正常时重新开始
标签: objective-c nsurlsession ios11 nsurlsessiondatatask