为了节约流量,同时也是为了更好的用户体验,目前很多应用都使用本地缓存机制,其中以网易新闻的缓存功能最为出色。我自己的应用也想加入本地缓存的功能,于是我从网上查阅了相关的资料,发现总体上说有两种方法。一种是自己写缓存的处理,一种是采用ASIHTTPRequest中的ASIDownloadCache。
 

方法一:一般将服务器第一次返回的数据保存在沙盒里面。这样在手机断网的情况下可以从本地读取数据了。

1.保存到沙盒的代码:

 

[plain] view plaincopy
  1. (void)saveCache:(int)type andID:(int)_id andString:(NSString *)str;  
  2.  
  3.     NSUserDefaults setting [NSUserDefaults standardUserDefaults];  
  4.     NSString key [NSString stringWithFormat:@"detail-%d-%d",type, _id];  
  5.     [setting setObject:str forKey:key];  
  6.     [setting synchronize];  
  7.  

2.读取本地沙盒的代码

 

读取之前首先根据type和Id判断本地是否有

 

[plain] view plaincopy
  1. (NSString *)getCache:(int)type andID:(int)_id  
  2.  
  3.     NSUserDefaults settings [NSUserDefaults standardUserDefaults];  
  4.     NSString *key [NSString stringWithFormat:@"detail-%d-%d",type, _id];  
  5.       
  6.     NSString *value [settings objectForKey:key];  
  7.     return value;  
  8.  

如果沙盒里面有数据

 

[plain] view plaincopy
  1. NSString *value [Tool getCache:5 andID:self.QiuTime];  
  2.         if (value)  
  3.             NSDictionary *backdict [value JSONValue];  
  4.             if ([backdict objectForKey:@"items"])  
  5.                 NSArray *array=[NSArray arrayWithArray:[backdict objectForKey:@"items"]];  
  6.                 for (NSDictionary *qiushi in array)  
  7.                     QiuShi *qs=[[[QiuShi alloc]initWithDictionary:qiushi] autorelease];  
  8.                     [self.list addObject:qs];  
  9.                  
  10.              
  11.             [self.tableView reloadData];  
  12.              
  13.          
  14.           
  15.         [self.tableView tableViewDidFinishedLoadingWithMessage:@"数据全部加载完了.."];  
  16.         self.tableView.reachedTheEnd  YES;  

 

方法二:使用ASIHTTPRequest和ASIDownloadCache实现本地缓存

 

1、设置全局的Cache
    在AppDelegate.h中添加一个全局变量

 

[plain] view plaincopy
 
  1. @interface AppDelegate UIResponder   
  2.  
  3.     ASIDownloadCache *myCache;  
  4.  
  5. @property (strong, nonatomic) UIWindow *window;  
  6. @property (nonatomic,retain) ASIDownloadCache *myCache;  

   在AppDelegate.m中的- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions方法中添加如下代码

 

 

[plain] view plaincopy
 
  1. //自定义缓存  
  2. ASIDownloadCache *cache [[ASIDownloadCache alloc] init];  
  3. self.myCache cache;  
  4. [cache release];  
  5.       
  6. //设置缓存路径  
  7. NSArray *paths NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);  
  8. NSString *documentDirectory [paths objectAtIndex:0];  
  9. [self.myCache setStoragePath:[documentDirectory stringByAppendingPathComponent:@"resource"]];  
  10. [self.myCache setDefaultCachePolicy:ASIOnlyLoadIfNotCachedCachePolicy];  
    

 

    在AppDelegate.m中的dealloc方法中添加如下语句

 

[plain] view plaincopy
 
  1. [myCache release];  

    到这里为止,就完成了全局变量的声明。

 

    2、设置缓存策略

    在实现ASIHTTPRequest请求的地方设置request的存储方式,代码如下

 

[plain] view plaincopy
 
  1. NSString *str @"http://....../getPictureNews.aspx";  
  2. NSURL *url [NSURL URLWithString:str];  
  3. ASIHTTPRequest *request [ASIHTTPRequest requestWithURL:url];  
  4. //获取全局变量  
  5. AppDelegate *appDelegate [[UIApplication sharedApplication] delegate];  
  6. //设置缓存方式  
  7. [request setDownloadCache:appDelegate.myCache];  
  8. //设置缓存数据存储策略,这里采取的是如果无更新或无法联网就读取缓存数据  
  9. [request setCacheStoragePolicy:ASICachePermanentlyCacheStoragePolicy];  
  10. request.delegate self;  
  11. [request startAsynchronous];  

    3、清理缓存数据

 

    我在这里采用的是手动清理数据的方式,在适当的地方添加如下代码,我将清理缓存放在了应用的设置模块:

 

[plain] view plaincopy
 
  1. AppDelegate *appDelegate [[UIApplication sharedApplication] delegate];  
  2. [appDelegate.myCache clearCachedResponsesForStoragePolicy:ASICachePermanentlyCacheStoragePolicy];  

 

 

    这里清理的是ASICachePermanentlyCacheStoragePolicy这种存储策略的缓存数据,如果更换其他的参数的话,即可清理对应存储策略的缓存数据。
arrow
arrow
    全站熱搜

    戮克 發表在 痞客邦 留言(0) 人氣()