Reputation: 1864
In my app I try to upload some data to a server when the app enters the background. This is the code I am using:
self.session = [self backgroundSession];
This is how my session is set up
- (NSURLSession *)backgroundSession
{
static NSURLSession *session = nil;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
NSURLSessionConfiguration *configuration = [NSURLSessionConfiguration backgroundSessionConfiguration:@"com.uploadSession"];
configuration.HTTPMaximumConnectionsPerHost = 1;
session = [NSURLSession sessionWithConfiguration:configuration delegate:self delegateQueue:nil];
});
return session;
}
- (void)applicationDidEnterBackground:(UIApplication *)application
{
[self uploadPossibleDrives];
}
// Start uploading the remaing gps log in th right order:
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
[queue setMaxConcurrentOperationCount:1];
for (int i = 0; i < arrayOfGPSLogChunks.count; i++)
{
// This will ensure the chunks are sent in the right order
// Add an operation as a block to a queue:
[queue addOperationWithBlock: ^ {
NSData *requestData;
NSMutableURLRequest *request;
if (i == 0)
{
NSLog(@"Initial drive upload %i",ID.integerValue);
requestData = [NSJSONSerialization dataWithJSONObject:historyToUpload options:NSJSONWritingPrettyPrinted error:nil];
request = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:kInitialUploadDriveURL];
[request setHTTPMethod:@"POST"];
[request setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[request setValue:[NSString stringWithFormat:@"%d", [requestData length]] forHTTPHeaderField:@"Content-Length"];
}
else
{
NSLog(@"Chunk %i",i);
NSMutableDictionary *chunk = [[NSMutableDictionary alloc] init];
[chunk setObject:driveID forKey:@"driveID"];
[chunk setObject:[arrayOfGPSLogChunks objectAtIndex:i] forKey:@"gpsLog"];
requestData = [NSJSONSerialization dataWithJSONObject:chunk options:NSJSONWritingPrettyPrinted error:nil];
request = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:kUploadDrivesChunkURL]];
[request setHTTPMethod:@"POST"];
[request setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[request setValue:[NSString stringWithFormat:@"%d", [requestData length]] forHTTPHeaderField:@"Content-Length"];
}
NSLog(@"_session: %@",self.session);
NSLog(@"request: %@",request);
NSLog(@"requestData: %lu",(unsigned long)requestData.length);
NSLog(@"uploadTask: %@",self.uploadTask);
self.uploadTask = [self.session uploadTaskWithRequest:request fromData:requestData];
[self.uploadTask resume];
if (i == arrayOfGPSLogChunks.count-1)
{
// All gps logs were uploaded so now we save its state as 'uploaded to server':
NSLog(@"Finished sending to server!");
[self setSentToServerForDriveID:ID];
}
}];
}
Now here is the error I get:
I do hope somebody can help me out. I have looked into everything I know but cant seem to figure out what ist going wrong. I also tried uploading without using the blocks but the result is the same.
Any help would be greatly appreciated!
Upvotes: 0
Views: 1218
Reputation: 1631
For a NSURLSession created with a backgroundSessionConfiguration, you have to use uploadTaskWithRequest:fromFile:
.
See this question: NSURLSession and stream upload in background
Upvotes: 2