Не удается получить ход загрузки в AFNetworking

Я пытаюсь загрузить файл с помощью AFNetworking 2.0, используя следующий фрагмент кода.

AFHTTPRequestSerializer *serialize = [AFHTTPRequestSerializer new];
[serialize setAuthorizationHeaderFieldWithUsername...// set the auth header with username and password
serialize.timeoutInterval = 200;
NSError *error = nil;
NSMutableURLRequest *request = [serialize requestWithMethod:@"GET" URLString:url parameters:nil error:&error];
AFHTTPSessionManager *session = [AFHTTPSessionManager manager];
NSProgress *progress = nil;

NSURLSessionDownloadTask *downloadTask = [session downloadTaskWithRequest:request progress:&progress destination:^NSURL *(NSURL *targetPath, NSURLResponse *response) {
    NSLog(@"success….”);
    NSURL *url = [NSURL new];
    return url;
} completionHandler:^(NSURLResponse *response, NSURL *filePath, NSError *error) {
    NSLog(@"error: %@", error.localizedDescription);
    }];

[progress addObserver:self forKeyPath:@"fractionCompleted" options:NSKeyValueObservingOptionNew context:NULL];
[downloadTask resume];
}

// Добавляем сюда наблюдателя для прогресса

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{

dispatch_async(dispatch_get_main_queue(), ^{
    if ([keyPath isEqualToString:@"fractionCompleted"]) {
        NSProgress *progress = (NSProgress *)object;
        NSLog(@"Progress… %f total unit count =%lld , completed unit count =%lld", progress.fractionCompleted , progress.totalUnitCount,progress.completedUnitCount);
    } else {
        [super observeValueForKeyPath:keyPath ofObject:object change:change context:context];
    }
});

}

А вот NSLog из метода observeValueForKeyPath

SampleDownload[5833:149756] Progress… 0.000000 total unit count =-1 , completed unit count =0
SampleDownload[5833:149756] Progress… 0.000000 total unit count =-1 , completed unit count =975
SampleDownload[5833:149767] Progress… 0.000000 total unit count =-1 , completed unit count =25149
SampleDownload[5833:149767] Progress… 0.000000 total unit count =-1 , completed unit count =31086
SampleDownload[5833:149767] Progress… 0.000000 total unit count =-1 , completed unit count =53006
SampleDownload[5833:149754] Progress… 0.000000 total unit count =-1 , completed unit count =54377
SampleDownload[5833:149755] Progress… 0.000000 total unit count =-1 , completed unit count =66098
SampleDownload[5833:149768] Progress… 0.000000 total unit count =-1 , completed unit count =93626
SampleDownload[5833:149763] Progress… 0.000000 total unit count =-1 , completed unit count =103805

Итак, как вы можете видеть, общее количество единиц, которое я получаю, равно -1. В результате я думаю, что fractionCompleted равно 0, и я не могу обновить пользовательский интерфейс. В чем ошибка, которую я делаю?

Я использовал это как ссылку. Как узнать ход загрузки в AFNetworking 2.0?

Также в этой теме происходит подобное обсуждение, но я не смог понять причину. https://github.com/AFNetworking/AFNetworking/issues/1398

ИЗМЕНИТЬ

Публикация заголовка ответа

{
"Access-Control-Allow-Credentials" = true;
"Access-Control-Allow-Headers" = "Accept,Authorization,Cache-Control,Content-Type,DNT,If-Modified-Since,Keep-Alive,Origin,User-Agent,X-Mx-ReqToken,X-Requested-With";
"Access-Control-Allow-Methods" = "GET, POST, PUT, DELETE, OPTIONS";
"Access-Control-Allow-Origin" = "*";
"Cache-Control" = "public, max-age=43200";
Connection = "keep-alive";
"Content-Encoding" = gzip;
"Content-Length" = 1166764;
"Content-Type" = "application/pdf";
Date = "Wed, 17 Dec 2014 12:17:43 GMT";
Etag = “someEtag”;
Expires = "Thu, 18 Dec 2014 00:17:43 GMT";
"Last-Modified" = "Wed, 17 Dec 2014 11:58:31 GMT";
Server = "nginx/1.4.6 (Ubuntu)";
Vary = "Accept-Encoding";
}

person shshnk    schedule 17.12.2014    source источник
comment
Проверьте, возвращает ли сервер Content-Length   -  person Ben Affleck    schedule 17.12.2014
comment
@Энди Спасибо! обновил детали вопроса с заголовком ответа, который я получаю.   -  person shshnk    schedule 17.12.2014
comment
Хм, я не знаю, мне все кажется законным ..   -  person Ben Affleck    schedule 17.12.2014
comment
См. stackoverflow.com/questions/9550971/afnetworking-progress и stackoverflow.com/questions/7417610/ (и помните что при поиске этого в Google, если вы включаете -1 в условия поиска, я думаю, что он исключает все страницы, на которых упоминается число 1, положительное или отрицательное! - — это Удалить оператор слов.)   -  person Matt Gibson    schedule 19.12.2014


Ответы (1)


Проблема может заключаться в Content-Encoding из gzip, из-за чего метод NSURLSessionDownloadDelegate didWriteData может возвращать -1 для ожидаемого общего количества байтов. Вы можете попробовать отключить gzip, установив Accept-Encoding перед отправкой запроса:

[request setValue:@"" forHTTPHeaderField:@"Accept-Encoding"];
person Rob    schedule 19.12.2014