苦苦看了我兩天,最近后台為了減輕壓力,要我做緩存,我說好吧......
借鑒了別人的說法找到一張圖可以看明白好多:
這個是我比較戰成一種方案。
好了直接上代碼了
首先我們要有自己緩存的類 說以就自己用讀寫方式簡單寫了一個類
+ (void)cacheForData:(NSData *)data fileName:(NSString *)fileName
{
NSString *path = [kCachePath stringByAppendingPathComponent:[YBMD5 md5:fileName]];
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[data writeToFile:path atomically:YES];
});
}
+ (NSData *)getCacheFileName:(NSString *)fileName
{
NSString *path = [kCachePath stringByAppendingPathComponent:[YBMD5 md5:fileName]];
return [[NSData alloc] initWithContentsOfFile:path];
}
+ (NSUInteger)getAFNSize
{
NSUInteger size = 0;
NSFileManager *fm = [NSFileManager defaultManager];
NSDirectoryEnumerator *fileEnumerator = [fm enumeratorAtPath:kCachePath];
for (NSString *fileName in fileEnumerator) {
NSString *filePath = [kCachePath stringByAppendingPathComponent:fileName];
NSDictionary *attrs = [[NSFileManager defaultManager] attributesOfItemAtPath:filePath error:nil];
size += [attrs fileSize];
}
return size;
}
這些大家都有自己的方式 。
然后開始在我們的AF中寫一些東西 就可以了
-(AFHTTPSessionManager *)manager{
static AFHTTPSessionManager *rmanager = nil;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
rmanager = [AFHTTPSessionManager manager];
rmanager.responseSerializer = [AFJSONResponseSerializer serializer];
rmanager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/json", @"text/javascript",@"text/html",@"text/plain",@"image/jpg",@"application/x-javascript",@"keep-alive", nil];
// 設置超時時間
[rmanager.requestSerializer willChangeValueForKey:@"timeoutInterval"];
rmanager.requestSerializer.timeoutInterval = 60.f;
[rmanager.requestSerializer didChangeValueForKey:@"timeoutInterval"];
});
return rmanager;
}
-(void)requsetWithPath:(NSString *)path withParams:(NSDictionary *)params withCacheType:(YBCacheType)cacheType withRequestType:(NetworkRequestType)type withResult:(ZmzBlock)resultBlock{
if (!self.isConnected) {
NSLog(@"沒有網絡,建議在手機設置中打開網絡");
// return;
}
switch (type) {
case NetworkGetType:
{
YBCache *cache = [self getCache:cacheType url:path params:params withResult:resultBlock];
NSString *fileName = cache.fileName;
if (cache.result) return;
[self.manager GET:path parameters:params progress:^(NSProgress * _Nonnull downloadProgress) {
YBLog(@"---------%lld", downloadProgress.totalUnitCount);
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
if (resultBlock) {
//緩存數據
NSData *data = [NSJSONSerialization dataWithJSONObject:responseObject options:NSJSONWritingPrettyPrinted error:nil];
[YBCacheTool cacheForData:data fileName:fileName];
[self handleRequestResultWithDataTask:task responseObject:responseObject error:nil resultBlock:resultBlock];
}
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
[self handleRequestResultWithDataTask:task responseObject:nil error:error resultBlock:resultBlock];
}];
}
break;
case NetworkPostType:
{
NSString *cutPath = [NSString stringWithFormat:@"%@%@",MAIN_URLL,path];
//緩存數據的文件名 data
YBCache *cache = [self getCache:cacheType url:cutPath params:params withResult:resultBlock];
NSString *fileName = cache.fileName;
if (cache.result) return;
[self.manager POST:cutPath parameters:params progress:^(NSProgress * _Nonnull uploadProgress) {
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
if (resultBlock) {
//緩存數據
NSData *data = [NSJSONSerialization dataWithJSONObject:responseObject options:NSJSONWritingPrettyPrinted error:nil];
[YBCacheTool cacheForData:data fileName:fileName];
[self handleRequestResultWithDataTask:task responseObject:responseObject error:nil resultBlock:resultBlock];
}
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
[self handleRequestResultWithDataTask:task responseObject:nil error:error resultBlock:resultBlock];
}];
}
break;
default:
break;
}
}
這樣大致的步驟就搞定了,可以根據自己的項目需求來定。
這只是成功的第一步 之后又整了半天 整理到了git上去
https://github.com/walkingzmz/MZAFNetworking
有興趣的可以一起討論下。
