iOS NSURLConnection & AFNetworking 缓存机制

// 联系人 : 石虎   QQ: 1224614774 昵称 : 嗡嘛呢叭咪哄

一. URL缓存基本概念

NSURLCache 提供了 内存与磁盘 的缓存机制。

任何通过NSURLConnection 加载的请求都会 NSURLCache 处理,因为 AFNetworking 使用了NSURLConnection ,所以也会被处理。
当完成数据的请求后,缓存的相应被保存在本地(沙盒目录为Library/Cache/<boundleId>目录下,每一个不同的请求会生成一个文件夹,保存的文件为NSData文件。)当下一次同样的请求时,直接从缓存中获取即可。
       因此网络缓存减少了与服务器的负担,并提高应用程序更好的体验。

二 :设置NSURLCache
1. 使用URL缓存首先要使NSURLCache进行初始化。URL 缓存默认大小为Memory 4 * 1024 * 1024 btye Disk 20 * 1024 * 1024byts
2. 在首次使用URL换粗之前就初始化NSURLCache,这样才能使用URL缓存,因此通常情况下在 application: didFinishLaunchingWithOptions--- 初始化,这样这个程序所有的NSMutableRequest 都能使用URL缓存。当然,你也写在自己网络请求的 单例初始化里

NSURLCache * cache = [[NSURLCachealloc] initWithMemoryCapacity:5 * 1024 * 1024
                                             diskCapacity:25 * 1024 * 1024
                                                 diskPath:nil];
[NSURLCachesetSharedURLCache:cache];

三 : 设置NSMutableURLRequest的requestsetCachePolicy即缓存策略

   NSURLRequestUseProtocolCachePolicy= 0,默认缓存策略。具体工作:如果一个NSCachedURLResponse对于请求并不存在,数据将会从源端获取。如果请求拥有一个缓存的响应,那么URL加载系统会检查这个响应来决定,如果它指定内容必须重新生效的话,将建立一个连向源端的连接来查看内容是否发生变化。假如内容没有变化,那么响应就从本地缓存返回数据。如果内容变化了,那么数据将从源端获取。
   NSURLRequestReloadIgnoringLocalCacheData = 1,URL应该加载源端数据,不使用本地缓存数据
      NSURLRequestReloadIgnoringCacheData =NSURLRequestReloadIgnoringLocalCacheData, 两个的设置相同


   NSURLRequestReturnCacheDataElseLoad = 2 ,指定已存的缓存数据应该用来响应请求,不管它的生命时长和过期时间。如果在缓存中没有已存数据来响应请求的话,数据从源端加载。

      NSURLRequestReturnCacheDataDontLoad = 3,指定已存的缓存数据用来满足请求,不管生命时长和过期时间。如果在缓存中没有已存数据来响应URL加载请求的话,不去尝试从源段加载数据,此时认为加载请求失败。这个常量指定了一个类似于离线模式的行为
 
  NSURLRequestReloadIgnoringLocalAndRemoteCacheData =4,本地缓存数据、代理和其他中介都要忽视他们的缓存,直接加载源数据
    
  
   NSURLRequestReloadRevalidatingCacheData = 5指定如果已存的缓存数据被提供它的源段确认为有效则允许使用缓存数据响应请求,否则从源段加载数据。
  只有响应http和https的请求会被缓存。ftp和文件协议当被缓存策略允许的时候尝试接入源段。自定义的NSURLProtocol类能够保护缓存,如果它们被选择使用的话。

示例:
NSMutableURLRequest * request =[NSMutableURLRequest requestWithURL:[NSURLURLWithString:@"http://www.sina.com"]];
   [requestsetCachePolicy:NSURLRequestReturnCacheDataDontLoad];


四 :URL缓存的使用
1  获取缓存

NSCachedURLResponse * response =[cache cachedResponseForRequest:request];
   
    if (response != nil) {
     
      NSLog(@"有缓存");
       [requestsetCachePolicy:NSURLRequestReturnCacheDataDontLoad];
 
    }else{
              NSLog(@"没有缓存");
           }
缓存策略 typedef NS_ENUM(NSUInteger, YBCacheType){ YBCacheTypeReturnCacheDataThenLoad = 0,///< 有缓存就先返回缓存,同步请求数据 YBCacheTypeReloadIgnoringLocalCacheData, ///< 忽略缓存,重新请求 YBCacheTypeReturnCacheDataElseLoad,///< 有缓存就用缓存,没有缓存就重新请求(用于数据不变时) YBCacheTypeReturnCacheDataDontLoad,///< 有缓存就用缓存,没有缓存就不发请求,当做请求出错处理(用于离线模式) YBCacheTypeReturnCacheDataExpireThenLoad///< 有缓存就用缓存,如果过期了就重新请求 没过期就不请求 }; //get请求 - (void)test_get { NSString *url = @"http://www.baidu.com"; NSDictionary *params = @{@"i":@"1"}; [YBHttpTool get:url params:params success:^(NSDictionary *obj) { //成功 } failure:^(NSError *error) { //失败 }]; } //get带缓存的请求 - (void)test_get_cache { NSString *url = @"http://www.baidu.com"; NSDictionary *params = @{@"i":@"1"}; [YBHttpTool get:url params:params cacheType:YBCacheTypeReturnCacheDataThenLoad success:^(NSDictionary *obj) { //成功 } failure:^(NSError *error) { //失败 }]; } //post请求带缓存 - (void)test_post_cache { NSString *url = @"http://www.baidu.com"; NSDictionary *params = @{@"i":@"1"}; [YBHttpTool post:url params:params cacheType:YBCacheTypeReturnCacheDataThenLoad success:^(NSDictionary *obj) { //成功 } failure:^(NSError *error) { //失败 }]; } //上传单张图片 - (void)test_upload_image { UIImage *image = [UIImage imageNamed:@"1"]; NSData *data = UIImageJPEGRepresentation(image, 0.5); [YBHttpTool uploadImageWithImage:data success:^(NSDictionary *obj) { //上传成功 } failure:^(NSError *error) { //上传失败 }]; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值