AFHTTPSessionManager ПОЛУЧИТЬ заморозку / зависание?
Недавно я столкнулся с проблемой с одним из наших клиентов, которые имеют очень медленное интернет-соединение, а также используют GroundControl. Каждый раз, когда они пытаются загрузить мое приложение, они застревают на экране загрузки "Попытка подключиться к серверу". Я знаю, что в коде он должен застрять здесь (см. Код ниже), потому что ни успех, ни неудача никогда не вызываются (если бы они были приложением, оно, по крайней мере, развивалось бы).
NSURL *ourTable = [NSURL URLWithString:[[NSString stringWithFormat: @"%@://%@%@/bla/%@/bla/bla/Reachability",
(useSSLB == YES) ? @"https" : @"http", server, port, self.globalSettings.env]
stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
manager.responseSerializer = [AFJSONResponseSerializer serializer];
[manager GET:ourTable.absoluteString parameters:nil progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"ONLINE..");
[self.ourSyncClass functionThatGetsCalledWhenSuccess;
[NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(syncOther) userInfo:nil repeats:NO];
startSync = YES; //Bool value used for other stuffs
NSLog(@"Syncing Data");
[manager invalidateSessionCancelingTasks:YES];
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"FAILED TO CONNECT TO SERVER. %@", error);
self.offline = YES; //bool used for other stuff
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:1.0];
[self.homeViewControllerInstance.syncView setAlpha:0.0];
[UIView commitAnimations];
[self.ourSyncClass createDB];
[self.ourSyncClass openDB];
[self startCustomFunction;
[manager invalidateSessionCancelingTasks:YES];
}];
Почему наш код застревает (блокируется?) В этом блоке завершения GET? Это связано с медленным интернет-соединением? Может ли это быть как-то связано с GroundControl? Как я могу справиться с такой ситуацией?
1 ответ
Ну, я в конечном итоге выяснил проблему. Оказывается, в нашем коде была логическая ошибка, из-за которой объект ourSyncClass не инициализировался каждый раз, когда выполнялся этот фрагмент кода. По какой-то причине это блокировало блокировку завершения. Итак, мы включили проверку вроде if(self.ourSyncClass!= Nil) {
} вокруг кода, и теперь все, кажется, работает правильно. Я отправлю обновление после того, как мы получим ответ от нашего клиента.