Zip 编码类

CodeIgniter的zip编码类允许你创建ZIP压缩文档。文档可以保存在你的桌面或者某个文件夹里

初始化

与其他CodeIgniter里的类一样,ZIP类在控制器里完成初始化工作,函数:$this->load->library

  1. $this->load->library('zip');
一旦加载,ZIP库对象可以用_$this->zip_来使用 ## 使用样例 这个例子演示了如何压缩一个文件并保存到你服务器一个文件夹,然后下载到你的桌面上。
  1. $name = 'mydata1.txt';
  2. $data = 'A Data String!';
  3. $this->zip->add_data($name, $data);
  4. // 在你的服务器的文件夹里写.zip文件。命名为"my_backup.zip"
  5. $this->zip->archive('/path/to/directory/my_backup.zip');
  6. // 下载此文件到桌面,命名为"my_backup.zip"
  7. $this->zip->download('my_backup.zip');

函数参考

$this->zip->add_data()

添加数据进zip文件里. 第一个参数是文件名, 第二个参数是你要添加的数据的字符串格式:

  1. $name = 'my_bio.txt';
  2. $data = 'I was born in an elevator...';
  3. $this->zip->add_data($name, $data);
允许你多次调用这个函数按顺序的添加若干个文件到你的存档。例子:
  1. $name = 'mydata1.txt';
  2. $data = 'A Data String!';
  3. $this->zip->add_data($name, $data);
  4. $name = 'mydata2.txt';
  5. $data = 'Another Data String!';
  6. $this->zip->add_data($name, $data);
或者你可以使用一个数组来传递多个文件(的值):
  1. $data = array(
  2. 'mydata1.txt' => 'A Data String!',
  3. 'mydata2.txt' => 'Another Data String!'
  4. );
  5. $this->zip->add_data($data);
  6. $this->zip->download('my_backup.zip');
如果你希望将压缩后的数据放入子文件夹内,请把路径作为文件名的一部分包含进去:
  1. $name = 'personal/my_bio.txt';
  2. $data = 'I was born in an elevator...';
  3. $this->zip->add_data($name, $data);
上面的例子将放置 _my_bio.txt_ 到一个叫personal的文件夹内。 ## $this->zip->add_dir() 允许你添加一个目录。通常这个函数是不必要的,因为当你使用_$this->zip->add_data()_, 可以把你的数据放进目录里,但是如果你想要创建一个空目录的话你也可以这样做。例子:
  1. $this->zip->add_dir('myfolder'); // Creates a folder called "myfolder"

$this->zip->read_file()

允许你压缩一个服务器某处存在的文件。提供一个文件路径,zip类将读取它并添加到存档:

  1. $path = '/path/to/photo.jpg';
  2. $this->zip->read_file($path);
  3. // Download the file to your desktop. Name it "my_backup.zip"
  4. $this->zip->download('my_backup.zip');
如果你想压缩文档保持原来文件的目录结构,可以把第二个参数设置为 TRUE (布尔值)。例子:
  1. $path = '/path/to/photo.jpg';
  2. $this->zip->read_file($path, TRUE);
  3. // Download the file to your desktop. Name it "my_backup.zip"
  4. $this->zip->download('my_backup.zip');
在上边的例子中,_photo.jpg_将被放到两层文件夹中:path/to/ ## $this->zip->read_dir() 允许你压缩一个服务器某处存在的文件夹(以及它里面的文件和子文件夹)。提供一个文件夹路径,zip类将递归读取它并重新创建添加到存档。 你所提供的路径下面的所有文件都会被压缩进来,也包括所有子文件夹。例如:
  1. $path = '/path/to/your/directory/';
  2. $this->zip->read_dir($path);
  3. // 将文件下载到你的桌面上,命名为 "my_backup.zip"
  4. $this->zip->download('my_backup.zip');
默认Zip文件会把第一个参数的完整文件夹路径保存到Zip文件里。如果你想忽略目标路径之前的文件夹结构,你可以传递 FALSE (布尔值) 到第二个参数。 例如:
  1. $path = '/path/to/your/directory/';
  2. $this->zip->read_dir($path, FALSE);
这将创建一个包括"directory"在内的ZIP文件, 所有的子文件夹被正确地保存在里面, 但是不包括此文件夹 /path/to/your. ## $this->zip->archive() 将Zip压缩文件写入服务器的一个目录下。请提交一个有效的服务器路径,以文件名作为结尾,并确保那个目录是可写的(权限为666或者777都可以)。例如:
  1. $this->zip->archive('/path/to/folder/myarchive.zip'); // 创建一个名为 myarchive.zip 的文件

$this->zip->download()

本函数将使用户从你的服务器上下载一个Zip文件。你必须把你想要使用的文件名作为参数传递给函数。例如:

  1. $this->zip->download('latest_stuff.zip'); // 文件将被命名为"latest_stuff.zip"
**说明:** 在调用本函数的控制器中不要显示任何数据,因为本函数将发送多个服务器header,从而使文件以二进制的形式被下载。 ## $this->zip->get_zip() 返回经过Zip压缩后的文件数据。通常情况下你不需要用到本函数,除非你想对数据做特殊处理。例如:
  1. $name = 'my_bio.txt';
  2. $data = 'I was born in an elevator...';
  3. $this->zip->add_data($name, $data);
  4. $zip_file = $this->zip->get_zip();

$this->zip->clear_data()

Zip编码类会对你的zip数据进行缓存,因此,调用上面的各个函数时,你不需要每次都重新建立Zip文件。然而,如果你要创建多个有着各自不同数据的Zip文件的话,你可以在调用期间清理掉缓存。例如:

  1. $name = 'my_bio.txt';
  2. $data = 'I was born in an elevator...';
  3. $this->zip->add_data($name, $data);
  4. $zip_file = $this->zip->get_zip();
  5. $this->zip->clear_data();
  6. $name = 'photo.jpg';
  7. $this->zip->read_file("/path/to/photo.jpg"); // 读取文件内容
  8. $this->zip->download('myphotos.zip');

翻译贡献者:architectcom, felee, Hex, lomatus, skey, xwjie, yinzhili, yygcom