NSURLConnection não chama completo em várias exibições
Hoje cedo fiz a seguinte pergunta:Bloco do iOS sendo interrompido quando o modo de exibição é pressionado
A operação que mencionei (OP1) é na verdade uma "http get" para o meu servidor, usando NSURLConnection.
Depois de mais investigação, descobri que o bloco não "morre" realmente. O que realmente acontece é que a requisição é realmente SENT (o lado do servidor a registra), mesmo depois que a view é pressionada (verificada via [NSThread sleep: 10]). O servidor responde, mas NADA acontece no lado do aplicativo se a view2 foi pressionada! quase como se a conexão tivesse perdido seu delegado! Outra possibilidade que eu estou olhando é "o fato de que NSURLConnection está norsMainLoop relacionado? "
Alguém pode ajudar?
Pls não esquece que:
0. Tudo funciona bem, desde que a view2 não seja pressionada até a conclusão da operação.
1. O pedido é enviado assíncrono
2. Eu defino o delegado e ele funciona enquanto a exibição não mudar
3. ver1 inicia a operação usando a propriedade "referência do objeto singleton" "OP1Completed"
4. ver2 verifica a conclusão do OP1 via propriedade na "referência de objeto singleton"
5. ver2 Obtém o "resultado", indo para a propriedade "singleton.OP1Result"
Editar 1:
Ok, vamos ter algum código. Primeiro aqui está o código relevante do meu singleton (chamado "Interaction"):
-(void)loadAllContextsForUser:(NSString *)username{
userNameAux = username;
_loadingContextsCompleted = NO;
if (contextsLoaderQueue == NULL) {
contextsLoaderQueue = dispatch_queue_create("contextsLoaderQueue", NULL);
}
dispatch_async(contextsLoaderQueue, ^{
NSLog(@"Loading all contexts block started");
[self requestConnectivity];
dispatch_async(dispatch_get_main_queue(), ^{
[Util Get:[NSString stringWithFormat:@"%@/userContext?username=%@", Util.azureBaseUrl, [username stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]]
successBlock:^(NSData *data, id jsonData){
NSLog(@"Loading all contexts block succeeded");
if([userNameAux isEqualToString:username]){
_allContextsForCurrentUser = [[NSSet alloc]initWithArray: jsonData];
}
} errorBlock:^(NSError *error){
NSLog(@"%@",error);
} completeBlock:^{
NSLog(@"load all contexts for user async block completed.");
_loadingContextsCompleted = YES;
[self releaseConnectivity];
}];
});
while (!_loadingContextsCompleted) {
NSLog(@"loading all contexts block waiting.");
[NSThread sleepForTimeInterval:.5];
}
});
NSLog(@"Load All Contexts Dispatched. It should start at any moment if it not already.");
}
E aqui está a classe Util, que realmente lida com o pedido / resposta
-(id)initGet:(NSString *)resourceURL successBlock:(successBlock_t)successBlock errorBlock:(errorBlock_t)errorBlock completeBlock:(completeBlock_t)completeBlock;{
if(self=[super init]){
_data=[[NSMutableData alloc]init];
}
_successBlock = [successBlock copy];
_completeBlock = [completeBlock copy];
_errorBlock = [errorBlock copy];
NSURL *url = [NSURL URLWithString:resourceURL];
NSMutableURLRequest *request = [NSURLRequest requestWithURL:url];
[[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:YES];
//[_conn scheduleInRunLoop:[NSRunLoop mainRunLoop] forMode:NSDefaultRunLoopMode];
//[_conn start];
NSLog(@"Request Started.");
return self;
}
- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response
{
[_data setLength:0];
}
- (void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data
{
[_data appendData:data];
}
- (void)connectionDidFinishLoading:(NSURLConnection *)connection
{
id jsonObjects = [NSJSONSerialization JSONObjectWithData:_data options:NSJSONReadingMutableContainers error:nil];
id key = [[jsonObjects allKeys] objectAtIndex:0];
id jsonResult = [jsonObjects objectForKey:key];
_successBlock(_data, jsonResult);
_completeBlock();
}
- (void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error
{
_errorBlock(error);
_completeBlock();
}
E finalmente aqui está a parte relevante VC1 (empurrando em VC2)
- (IBAction)loginClicked {
NSLog(@"login clicked. Preparing to exibit next view");
UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard_iPhone" bundle:nil];
AuthenticationViewController *viewController = (AuthenticationViewController *)[storyboard instantiateViewControllerWithIdentifier:@"ContextSelectionView"];
NSLog(@"Preparation completed. pushing view now");
[self presentViewController:viewController animated:YES completion:nil];
}