ASI的缓存是ASI的一大特色,和苹果原生的NSURLCache一样,也提供了一个单例对象[ASIDownloadCache sharedCache]
1.ASI使用缓存的条件
1>必须是GET请求
2>请求成功,状态码是200
2.单个请求怎么使用ASI缓存
// 设置URL
NSURL *url = [NSURL URLWithString:@"http://localhots/123.png"];
// 初始化请求
ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];
// 监听请求
__weak typeof(request) temp = request; // 避免Block循环引用
[request setCompletionBlock:^{
NSLog(@"----%@",temp.responseString);
}];
// 设置请求的缓存策略
// 第1种方式,拿到ASIDownloadCache单例对象,设置默认缓存策略;然后将这个单例设置为request的downloadCache(成员变量)
ASIDownloadCache *cache = [ASIDownloadCache sharedCache];
[cache setDefaultCachePolicy:ASIOnlyLoadIfNotCachedCachePolicy | ASIFallbackToCacheIfLoadFailsCachePolicy];
[request setDownloadCache:cache];
// 第2种方式,不用ASIDownloadCache的单例对象,自己新建一个ASIDownloadCache对象,然后设置cache对象的缓存路径和默认缓存策略,然后将这个cache对象设置为request的downloadCache(成员变量)
ASIDownloadCache *myCache = [[ASIDownloadCache alloc]init];
myCache.storagePath = [[NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"myCache"];
myCache.defaultCachePolicy = ASIOnlyLoadIfNotCachedCachePolicy;
[request setDownloadCache:myCache];
// 设置请求的缓存时长,有2种,分别是会话缓存和硬盘缓存
[request setCacheStoragePolicy:ASICacheForSessionDurationCacheStoragePolicy];
补充说明:
Question1:为什么 ASIDownloadCache的单例对象,不需要设置缓存路径,而自定义的ASIDownloadCache对象就需要设置缓存路径?
因为[ASIDownloadCache sharedCache]方法里,已经设置了缓存路径,可以跳进这个方法里看看.
Question2:CachePolicy,CacheStoragePolicy分别代表什么含义?
CachePolicy表示什么时候加载缓存,什么时候加载网络数据
CacheStoragePolicy表示缓存的时长
3.多个请求怎么使用ASI缓存
// 设置请求1和请求2
NSURL *url1 = [NSURL URLWithString:@"xxxxxx"];
ASIHTTPRequest *request1 = [ASIHTTPRequest requestWithURL:url1];
NSURL *url2 = [NSURL URLWithString:@"xxxxxxxxxxxxx"];
ASIHTTPRequest *request2 = [ASIHTTPRequest requestWithURL:url2];
// 默认的缓存管理对象
ASIDownloadCache *cache = [ASIDownloadCache sharedCache];
[cache setDefaultCachePolicy:ASIOnlyLoadIfNotCachedCachePolicy | ASIFallbackToCacheIfLoadFailsCachePolicy];
// 设置请求1的缓存
[request1 setDownloadCache:cache];
request1.cachePolicy = ASIOnlyLoadIfNotCachedCachePolicy; // 根据就近原则,request1最终的cachePolicy=ASIOnlyLoadIfNotCachedCachePolicy
request1.cacheStoragePolicy = ASICacheForSessionDurationCacheStoragePolicy;
// 设置请求2的缓存
[request2 setDownloadCache:cache];
// request2没设置cachePolicy,所以request2的cachePolicy = 默认的缓存管理cache的DefaultCachePolicy
request2.cacheStoragePolicy =ASICachePermanentlyCacheStoragePolicy;
补充说明:
1>ASIDownloadCache作用就是设置request的缓存路径,另外1个作用是提供了默认的DefaultCachePolicy
2>在这个缓存路径下会有2个文件夹,1个是硬盘缓存,另1个是临时缓存,request.cacheStoragePolicy决定了缓存在具体哪个文件夹下.所以request.downloadCache 和 request.cacheStoragePolicy必须设置,只有这2个属性,都设置才能最终确定缓存 存储的路径
3>request.cachePolicy,可根据实际需求决定是否设置.
如果request要遵从全局的缓存策略,就不用设置,它会取ASIDownloadCache的DefaultCachePolicy
如果request有它自己个性化的地方,就要设置,它会根据就近原则,取自己的cachePolicy作为最终的缓存策略
示意图
4.每个request都要设置downloadCache还是比较麻烦,所以ASI提供了便捷方法
[ASIHTTPRequest setDefaultCache:[ASIDownloadCache sharedCache]];
5.缓存的其他特性
[request setSecondsToCache:60 * 60 * 24 * 7]; // 有效期7天
BOOL isUseCache = [request didUseCachedResponse]; // 判断数据是否来自缓存