SSZipArchive的使用详解和遇到的问题

一、使用详解:

我们在开发app的时候,有时会需要对文件进行压缩和解压的操作,这个时候我们就必须要用到一个第三方的开源库,SSZipArchive ,来对目标文件进行压缩和解压的操作。
SSZipArchive下载链接,引入到工程时需要添加 libz.tbd 库,否则编译时通不过。

压缩:

  1. //压缩  
  2. - (void)createZipFile {  
  3.     //目的路径  
  4.     NSString *destinationPath = @"/Users/Administrator/Desktop/wzg.zip";//注意是这个是 zip 格式的后缀  
  5.     //源文件路径  
  6.     NSString *sourceFilePath = @"/Users/Administrator/Desktop/wzg.txt";  
  7.     //数组里可以放多个源文件,这些文件会被同一打包成压缩包,到 destinationPath 这个路径下。  
  8.     if ([SSZipArchive createZipFileAtPath:destinationPath withFilesAtPaths:@[sourceFilePath]]) {  
  9.         NSLog(@"压缩成功");  
  10.     }  
  11.     else {  
  12.         NSLog(@"压缩失败");  
  13.     }  
  14. }  

解压:

  1. //解压  
  2. - (void)unzipFile {  
  3.     //源文件路径  
  4.     NSString *sourceFilePath = @"/Users/Administrator/Desktop/wzg.zip";  
  5.     //目的文件路径  
  6.     NSString *destinationPath = @"/Users/wangzhengang/Desktop/";  
  7.     //把 sourceFilePath 这个路径下的zip包,解压到这个 destinationPath 路径下  
  8.     if ([SSZipArchive unzipFileAtPath:sourceFilePath toDestination:destinationPath delegate:self uniqueId:nil]){  
  9.         NSLog(@"解压成功");  
  10.     }  
  11.     else {  
  12.         NSLog(@"解压失败");  
  13.     }  
  14. }  


代理方法:

  1. #pragma mark - SSZipArchiveDelegate  
  2. - (void)zipArchiveWillUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo {  
  3.     NSLog(@"将要解压。");  
  4. }  
  5.   
  6. - (void)zipArchiveDidUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo unzippedPath:(NSString *)unzippedPat uniqueId:(NSString *)uniqueId {  
  7.     NSLog(@"解压完成!");  
  8. }  

二、SSZipArchive所有方法说明:

  1. @interface SSZipArchive : NSObject  
  2.   
  3. // Unzip 解压  
  4. /** 
  5.  * @param          path    源文件 
  6.  * @param   destination    目的文件 
  7.  * @param      uniqueId    标记,用于区别多个解压操作 
  8.  * 
  9.  * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
  10.  */  
  11. + (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination  uniqueId:(NSString *)uniqueId;  
  12.   
  13. /** 
  14.  * @param          path    源文件 
  15.  * @param   destination    目的文件 
  16.  * @param     overwrite    YES 会覆盖 destination 路径下的同名文件,NO 则不会。 
  17.  * @param      password    需要输入密码的才能解压的压缩包 
  18.  * @param         error    返回解压时遇到的错误信息 
  19.  * @param      uniqueId    标记,用于区别多个解压操作 
  20.  * 
  21.  * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
  22.  */  
  23. + (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination overwrite:(BOOL)overwrite password:(NSString *)password error:(NSError **)error  uniqueId:(NSString *)uniqueId;  
  24.   
  25. /** 
  26.  * @param          path    源文件 
  27.  * @param   destination    目的文件 
  28.  * @param      delegate    设置代理 
  29.  * @param      uniqueId    标记,用于区别多个解压操作 
  30.  * 
  31.  * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
  32.  */  
  33. + (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination delegate:(id<SSZipArchiveDelegate>)delegate  uniqueId:(NSString *)uniqueId;  
  34.   
  35. /** 
  36.  * @param          path    源文件 
  37.  * @param   destination    目的文件 
  38.  * @param     overwrite    YES 会覆盖 destination 路径下的同名文件,NO 则不会。 
  39.  * @param      password    需要输入密码的才能解压的压缩包 
  40.  * @param         error    返回解压时遇到的错误信息 
  41.  * @param      delegate    设置代理 
  42.  * @param      uniqueId    标记,用于区别多个解压操作 
  43.  * 
  44.  * @return 返回 YES 表示成功,返回 NO 表示解压失败。 
  45.  */  
  46. + (BOOL)unzipFileAtPath:(NSString *)path toDestination:(NSString *)destination overwrite:(BOOL)overwrite password:(NSString *)password error:(NSError **)error delegate:(id<SSZipArchiveDelegate>)delegate uniqueId:(NSString *)uniqueId;  
  47.   
  48. // Zip 压缩  
  49. /** 
  50.  * @param       path    目的路径(格式:~/xxx.zip 结尾的路径) 
  51.  * @param  filenames    要压缩的文件路径 
  52.  * 
  53.  * @return 返回 YES 表示成功,返回 NO 表示压缩失败。 
  54.  */  
  55. + (BOOL)createZipFileAtPath:(NSString *)path withFilesAtPaths:(NSArray *)filenames;  
  56.   
  57. /** 
  58.  * @param       path    目的路径(格式:~/xxx.zip 结尾的路径) 
  59.  * @param  filenames    要压缩的文件目录路径 
  60.  * 
  61.  * @return 返回 YES 表示成功,返回 NO 表示压缩失败。 
  62.  */  
  63. + (BOOL)createZipFileAtPath:(NSString *)path withContentsOfDirectory:(NSString *)directoryPath;  
  64.   
  65. /** 
  66.  * 初始化压缩对象 
  67.  * 
  68.  * @param  path    目的路径(格式:~/xxx.zip 结尾的路径) 
  69.  * 
  70.  * @return 初始化后的对像 
  71.  */  
  72. - (id)initWithPath:(NSString *)path;  
  73.   
  74. /** 
  75.  *  打开压缩对象 
  76.  * @return 返回 YES 表示成功,返回 NO 表示失败。 
  77.  */  
  78. - (BOOL)open;  
  79.   
  80. /** 
  81.  * 添加要压缩的文件的路径 
  82.  * 
  83.  * @param  path    文件路径 
  84.  * 
  85.  * @return 返回 YES 表示成功,返回 NO 表示失败。 
  86.  */  
  87. - (BOOL)writeFile:(NSString *)path;  
  88.   
  89. /** 
  90.  * 向此路径的文件里写入数据 
  91.  * 
  92.  * @param      data    要写入的数据 
  93.  * @param  filename    文件路径 
  94.  * 
  95.  * @return 返回 YES 表示成功,返回 NO 表示失败。 
  96.  */  
  97. - (BOOL)writeData:(NSData *)data filename:(NSString *)filename;  
  98.   
  99. /** 
  100.  *  关闭压缩对象 
  101.  * @return 返回 YES 表示成功,返回 NO 表示失败。 
  102.  */  
  103. - (BOOL)close;  
  104.   
  105. @end  
  106.   
  107.   
  108. @protocol SSZipArchiveDelegate <NSObject>  
  109.   
  110. @optional  
  111.   
  112. //将要解压  
  113. - (void)zipArchiveWillUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo;  
  114. //解压完成  
  115. - (void)zipArchiveDidUnzipArchiveAtPath:(NSString *)path zipInfo:(unz_global_info)zipInfo unzippedPath:(NSString *)unzippedPat uniqueId:(NSString *)uniqueId;  
  116. //将要解压  
  117. - (void)zipArchiveWillUnzipFileAtIndex:(NSInteger)fileIndex totalFiles:(NSInteger)totalFiles archivePath:(NSString *)archivePath fileInfo:(unz_file_info)fileInfo;  
  118. //解压完成  
  119. - (void)zipArchiveDidUnzipFileAtIndex:(NSInteger)fileIndex totalFiles:(NSInteger)totalFiles archivePath:(NSString *)archivePath fileInfo:(unz_file_info)fileInfo;  
  120.   
  121. @end  

三、遇到的问题:

当对要压缩或者要解压的文件的文件名包含有中文文字时,这个时候会出现文件名乱码的问题,或者在目的路径下未能找到解压后的文件的问题。

解决办法:

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

更改后:


原文地址链接:http://blog.csdn.net/zhengang007/article/details/51019479
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值