IOS 知识积累ios-存储数据存储

iOS 开发_压缩·解压缩ZipArchive进度详解

2017-11-08  本文已影响47人  iOS_PM_WEB_尛鹏

【作者前言】:分享些本人工作中遇到的点点滴滴那些事儿,刚开始写博客,高手勿喷!以分享交流为主,欢迎各路豪杰点评改进!

1.应用场景:

很多时候,需要我们对App端包的大小进行瘦身,这个时候最直观方案就是将文件比较大的东东扔到服务端,经App下载后,在做二次扩容以支撑App的完整功能体验!

2.实现目标:

使用ZipArchive实现压缩,解压缩。 并对进度进行监听!

3.代码说明:

!!! 引入到工程时需要添加 libz.tbd 库,否则编译时通不过。 · !!!使用时,比较大的文件可以考虑新开辟子线程处理,避免耗时影响主线程流畅

//压缩
- (void)createZipFile {  
    //压缩完成后,zip文件存放的路径  
    NSString *destinationPath = @"***/zyp.zip";
    //需要压缩的文件路径  
    NSString *sourceFilePath = @***/zyp.txt";  
    //数组里可以放多个源文件,这些文件会被同一打包成压缩包,到 destinationPath 这个路径下。  
    if ([SSZipArchive createZipFileAtPath:destinationPath withFilesAtPaths:@[sourceFilePath]]) {  
        NSLog(@"压缩成功");  
    }  
    else {  
        NSLog(@"压缩失败");  
    }  
}  
//解压缩
- (void)unzipFile {  
    //需要解压的zip文件路径  
    NSString *sourceFilePath = @"***/zyp.zip";  
    //解压完成后,存放的文件路径  
    NSString *destinationPath = @"***/zypUnAr/";  
    //把 sourceFilePath 这个路径下的zip包,解压到这个 destinationPath 路径下  
    if ([SSZipArchive unzipFileAtPath:sourceFilePath toDestination:destinationPath delegate:self uniqueId:nil]){  
        NSLog(@"解压成功");  
    }  
    else {  
        NSLog(@"解压失败");  
    }  
}  
!!!可能遇到的问题
//当对要压缩或者要解压的文件的文件名包含有中文文字时,
这个时候会出现文件名乱码的问题,或者在目的路径下未能找到解压后的文件的问题。
## 解决办法:

在 SSZipArchive.m 文件中改一下对 文件路径的编码格式,即可。

更改前:
NSString *strPath = [NSString stringWithCString:filename encoding:NSUTF8StringEncoding];
更改后:
NSStringEncoding enc = CFStringConvertEncodingToNSStringEncoding (kCFStringEncodingGB_18030_2000);
NSString *strPath = [NSString stringWithCString:filename encoding:enc];

常用代理方法
#pragma mark - 🎱 SSZipArchiveDelegate  
- (void)zipArchiveWillUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo {  
    NSLog(@"将要解压。");  
}  
  
- (void)zipArchiveDidUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo unzippedPath:(NSString *)unzippedPat uniqueId:(NSString *)uniqueId {  
    NSLog(@"解压完成!");  
}  

全部代理方法标注:

@interface SSZipArchive : NSObject  
  
// Unzip 解压  
/** 
 * @param          path    源文件 
 * @param   destination    目的文件 
 * @param      uniqueId    标记,用于区别多个解压操作 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
 */  
+ (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination  uniqueId:(NSString *)uniqueId;  
  
/** 
 * @param          path    源文件 
 * @param   destination    目的文件 
 * @param     overwrite    YES 会覆盖 destination 路径下的同名文件,NO 则不会。 
 * @param      password    需要输入密码的才能解压的压缩包 
 * @param         error    返回解压时遇到的错误信息 
 * @param      uniqueId    标记,用于区别多个解压操作 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
 */  
+ (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination overwrite:(BOOL)overwrite password:(NSString *)password error:(NSError **)error  uniqueId:(NSString *)uniqueId;  
  
/** 
 * @param          path    源文件 
 * @param   destination    目的文件 
 * @param      delegate    设置代理 
 * @param      uniqueId    标记,用于区别多个解压操作 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
 */  
+ (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination delegate:(id<SSZipArchiveDelegate>)delegate  uniqueId:(NSString *)uniqueId;  
  
/** 
 * @param          path    源文件 
 * @param   destination    目的文件 
 * @param     overwrite    YES 会覆盖 destination 路径下的同名文件,NO 则不会。 
 * @param      password    需要输入密码的才能解压的压缩包 
 * @param         error    返回解压时遇到的错误信息 
 * @param      delegate    设置代理 
 * @param      uniqueId    标记,用于区别多个解压操作 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
 */  
+ (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination overwrite:(BOOL)overwrite password:(NSString *)password error:(NSError **)error delegate:(id<SSZipArchiveDelegate>)delegate uniqueId:(NSString *)uniqueId;  
  
// Zip 压缩  
/** 
 * @param       path    目的路径(格式:~/xxx.zip 结尾的路径) 
 * @param  filenames    要压缩的文件路径 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示压缩失败。 
 */  
+ (BOOL)createZipFileAtPath:(NSString *)path withFilesAtPaths:(NSArray *)filenames;  
  
/** 
 * @param       path    目的路径(格式:~/xxx.zip 结尾的路径) 
 * @param  filenames    要压缩的文件目录路径 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示压缩失败。 
 */  
+ (BOOL)createZipFileAtPath:(NSString *)path withContentsOfDirectory:(NSString *)directoryPath;  
  
/** 
 * 初始化压缩对象 
 * 
 * @param  path    目的路径(格式:~/xxx.zip 结尾的路径) 
 * 
 * @return 初始化后的对像 
 */  
- (id)initWithPath:(NSString *)path;  
  
/** 
 *  打开压缩对象 
 * @return 返回 YES 表示成功,返回 NO 表示失败。 
 */  
- (BOOL)open;  
  
/** 
 * 添加要压缩的文件的路径 
 * 
 * @param  path    文件路径 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示失败。 
 */  
- (BOOL)writeFile:(NSString *)path;  
  
/** 
 * 向此路径的文件里写入数据 
 * 
 * @param      data    要写入的数据 
 * @param  filename    文件路径 
 * 
 * @return 返回 YES 表示成功,返回 NO 表示失败。 
 */  
- (BOOL)writeData:(NSData *)data filename:(NSString *)filename;  
  
/** 
 *  关闭压缩对象 
 * @return 返回 YES 表示成功,返回 NO 表示失败。 
 */  
- (BOOL)close;  
  
@end  
  
  
@protocol SSZipArchiveDelegate <NSObject>  
  
@optional  
  
//将要解压  
- (void)zipArchiveWillUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo;  
//解压完成  
- (void)zipArchiveDidUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo unzippedPath:(NSString *)unzippedPat uniqueId:(NSString *)uniqueId;  
//将要解压  
- (void)zipArchiveWillUnzipFileAtIndex:(NSInteger)fileIndex totalFiles:(NSInteger)totalFiles archivePath:(NSString *)archivePath fileInfo:(unz_file_info)fileInfo;  
//解压完成  
- (void)zipArchiveDidUnzipFileAtIndex:(NSInteger)fileIndex totalFiles:(NSInteger)totalFiles archivePath:(NSString *)archivePath fileInfo:(unz_file_info)fileInfo;  
  
@end  
上一篇下一篇

猜你喜欢

热点阅读