在AFNetworking请求中忽略If-Modified-Since或If-None-Match标头

时间:2013-12-10 14:08:21

标签: caching afnetworking

我正在使用AFNetworking 1.3.3从Amazon S3获取静态JSON文件。如果我使用Google Chrome请求这些文件并检查标头,它会在请求中发送If-Modified-SinceIf-None-Match HTTP标头,并按预期返回一个很好的304响应。

但是,当我使用AFNetworking发出相同的请求时,发送相同的If-Modified-Since和相同的If-None-Match标头,我每次都会得到200,即使我知道内容未被修改。它似乎忽略了我发送的额外标题。

这是我的代码:

NSMutableURLRequest* request = [[NSMutableURLRequest alloc] initWithURL:feedUrl cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:60];

[request setValue:@"application/json" forHTTPHeaderField:@"Accept"];

if (feed.remoteLastModified != nil) {
    // In real life I use the last modified header returned by the request
    [request setValue:@"Tue, 10 Dec 2013 07:15:50 GMT" forHTTPHeaderField:@"If-Modified-Since"];
}

if (feed.remoteETag.length > 0) {
    NSLog(@"If-None-Match: %@", feed.remoteETag);
    [request setValue:feed.remoteETag forHTTPHeaderField:@"If-None-Match"];
}

NSLog(@"headers: %@", request.allHTTPHeaderFields);

AFJSONRequestOperation* operation = [AFJSONRequestOperation JSONRequestOperationWithRequest:request success:^(NSURLRequest* request, NSHTTPURLResponse* response, id JSON) {

    NSLog(@"Status code: %d", response.statusCode);        

} failure:^(NSURLRequest* request, NSHTTPURLResponse* response, NSError* error, id JSON) {
    if (response.statusCode != 304) {
        NSLog(@"There was an error: %@", [error userInfo]);
    } else {
        NSLog(@"Not modified");
    }
}];

[operation start];

1 个答案:

答案 0 :(得分:6)

问题是使用的缓存策略 - NSURLRequestUseProtocolCachePolicy NSURLCache将在幕后进行自己的缓存,并将透明地返回原始200响应的缓存结果。

如果您确实希望自己进行缓存,请使用NSURLRequestReloadIgnoringLocalCacheData缓存策略。这并不意味着它会忽略您的缓存标头(我最初假设) - 它只是意味着NSURLCache将忽略它自己的本地缓存。

然而,自己动手并重新发明轮子可能是错误的方法!