php数据流zip php输入流

php如何压缩一个文件夹里面所有的文件到zip文件里面?

//函数:文件压缩 //压缩参数:需要压缩的文件或文件夹(文件可为数组),压缩后的zip文件名及存放路径,压缩类型1:文件夹2:文件,后续操作1:压缩后下载;2:存放在服务器上(默认为/@Upload下) //压缩文件夹示例:Tozip("./","../".date("d-H-i-s").".zip",1,2); //压缩文件示例: // $aaa=array("../1.txt","../2.txt"); // Tozip($aaa,"../2.zip",2);FunctionTozip($Path, $ZipFile, $Typ=1, $Todo=1){//IF(!is_writeable($Path)){Exit("文件夹不可写!");}$Path=Str_iReplace("\\","/",($Path));IF(Is_Null($Path) OrEmpty($Path) Or!IsSet($Path)){ReturnFalse;}IF(Is_Null($ZipFile) OrEmpty($ZipFile) Or!IsSet($ZipFile)){ReturnFalse;} Include_once("inc/Class_Zip.php");$zip=NewPHPZip;IF(SubStr($Path,-1,1)=="/"){$Path=SubStr($Path,0, StrLen($Path)-1);} OB_end_clean();Switch($Typ){Case"1":$zip-ZipDir($Path, $ZipFile, $Todo);Break;Case"2":$zip-ZipFile($Path,

专注于为中小企业提供成都做网站、网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业独山免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

PHP流(Stream)的概述与使用详解

在现代 PHP 特性中,流或许是最出色但使用率最低的。虽然 PHP 4.3 就引入了流,但是很多开发者并不知道流的存在,因为人们很少提及流,而且流的文档也很匮乏。PHP 官方文档对流的解释如下:

可能看完这段解释后还是云里雾里,我们简化一下,流的作用是在出发地和目的地之间传输数据。出发地和目的地可以是文件、命令行进程、网络连接、ZIP 或 TAR 压缩文件、临时内存、标准输入或输出,或者是通过 PHP 流封装协议实现的任何其他资源。

如果你读写过文件,就用过流;如果你从 php://stdin 读取过数据,或者把输入写入 php://stdout ,也用过流。流为 PHP 的很多 IO 函数提供了底层实现,如 file_get_contents、fopn、fread 和 fwrite 等。PHP 的流函数提供了不同资源的统一接口。

我们可以把流比作管道,把水(资源数据)从一个地方引到另一个地方。在水从出发地到目的地的过程中,我们可以过滤水,可以改变水质,可以添加水,也可以排出水。

流式数据的种类各异,每种类型需要独特的协议,以便读写数据,我们称这些协议为 流封装协议 。例如,我们可以读写文件系统,可以通过 HTTP、HTTPS 或 SSH 与远程 Web 服务器通信,还可以打开并读写 ZIP、RAR 或 PHAR 压缩文件。这些通信方式都包含下述相同的过程:

1.开始通信

2.读取数据

3.写入数据

4.结束通信

虽然过程是一样的,但是读写文件系统中文件的方式与收发 HTTP 消息的方式有所不同,流封装协议的作用是使用通用的接口封装这种差异。

每个流都有一个协议和一个目标。指定协议和目标的方法是使用流标识符:scheme://target,其中 scheme 是流的封装协议,target 是流的数据源。

http://流封装协议

下面使用 HTTP 流封装协议创建了一个与 Flicker API 通信的 PHP 流:

不要以为这是普通的网页 URL,file_get_contents() 函数的字符串参数其实是一个流标识符。http 协议会让 PHP 使用 HTTP 流封装协议,在这个参数中,http 之后是流的目标。

我们通常使用 file_get_contents()、fopen()、fwrite() 和 fclose() 等函数读写文件系统,因为 PHP 默认使用的流封装协议是 file://,所以我们很少认为这些函数使用的是 PHP 流。下面的示例演示了使用 file:// 流封装协议创建一个读写 /etc/hosts 文件的流:

我们通常会省略掉 file:// 协议,因为这是 PHP 使用的默认值。

php://流封装协议

编写命令行脚本的 PHP 开发者会感激 php:// 流封装协议,这个流封装协议的作用是与 PHP 脚本的标准输入、标准输出和标准错误文件描述符通信。我们可以使用 PHP 提供的文件系统函数打开、读取或写入下面四个流:

1. php://stdin :这是个只读 PHP 流,其中的数据来自标准输入。PHP 脚本可以使用这个流接收命令行传入脚本的信息;

2. php://stdout :把数据写入当前的输出缓冲区,这个流只能写,无法读或寻址;

3. php://memory :从系统内存中读取数据,或者把数据写入系统内存。缺点是系统内存有限,所有使用 php://temp 更安全;

4. php://temp :和 php://memory 类似,不过,没有可用内存时,PHP 会把数据写入这个临时文件。

其他流封装协议

PHP 和 PHP 扩展还提供了很多其他流封装协议,例如,与 ZIP 和 TAR 压缩文件、FTP 服务器、数据压缩库、Amazon API、Dropbox API 等通信的流封装协议。需要注意的是,PHP 中的 fopen()、fgets()、fputs()、feof() 以及 fclose() 等函数不仅可以用来处理文件系统中的文件,还可以在所有支持这些函数的流封装协议中使用。

自定义流封装协议

我们还可以自己编写 PHP 流封装协议。PHP 提供了一个示例 StreamWrapper 类,演示如何编写自定义的流封装协议,支持部分或全部 PHP 文件系统函数。关于如何编写,具体请参考以下文档:

有些 PHP 流能够接受一系列可选的参数,这些参数叫流上下文,用于定制流的行为。不同的流封装协议使用的流上下文有所不同,流上下文使用 stream_context_create() 函数创建,这个函数返回的上下文对象可以传入大多数文件系统函数。

例如,你知道可以使用 file_get_contents() 发送 HTTP POST 请求吗?使用一个流上下文对象即可实现:

流过滤器

目前为止我们讨论了如何打开流,读取流中的数据,以及把数据写入流。不过,PHP 流真正强大的地方在于过滤、转换、添加或删除流中传输的数据,例如,我们可以打开一个流处理 Markdown 文件,在把文件内容读入内存的过程中自动将其转化为 HTML。

运行该脚本,输出的都是大写字母:

我们还可以使用 php://filter 流封装协议把过滤器附加到流上,不过,使用这种方式之前必须先打开 PHP 流:

这个方式实现效果和 stream_filter_append() 函数一样,但是相比之下更为繁琐。不过,PHP 的某些文件系统函数在调用后无法附加过滤器,例如 file() 和 fpassthru(),使用这些函数时只能使用 php://filter 流封装协议附加流过滤器。

自定义流过滤器

我们还可以编写自定义的流过滤器。其实,大多数情况下都要使用自定义的流过滤器,自定义的流过滤器是个 PHP 类,继承内置的 php_user_filter 类( ),且必须实现 filter()、onCreate() 和 onClose() 方法,最后,必须使用 stream_filter_register() 函数注册自定义的流过滤器。

然后,我们必须使用 stream_filter_register() 函数注册这个自定义的 DirtyWordsFilter 流过滤器:

第一个参数用于标识这个自定义过滤器的过滤器名,第二个参数是这个自定义过滤器的类名。接下来就可以使用这个自定义的流过滤器了:

修改 test.txt 内容如下:

运行上面的自定义过滤器脚本,结果如下:

stream_bucket_append函数:为队列添加数据 

stream_bucket_make_writeable函数:从操作的队列中返回一个数据对象

stream_bucket_new函数:为当前队列创建一个新的数据

stream_bucket_prepend函数:预备数据到队列 

stream_context_create函数:创建数据流上下文

stream_context_get_default函数:获取默认的数据流上下文

stream_context_get_options函数:获取数据流的设置

stream_context_set_option函数:对数据流、数据包或者上下文进行设置

stream_context_set_params函数:为数据流、数据包或者上下文设置参数

stream_copy_to_stream函数:在数据流之间进行复制操作

stream_filter_append函数:为数据流添加过滤器

stream_filter_prepend函数:为数据流预备添加过滤器

stream_filter_register函数:注册一个数据流的过滤器并作为PHP类执行

stream_filter_remove函数:从一个数据流中移除过滤器

stream_get_contents函数:读取数据流中的剩余数据到字符串

stream_get_filters函数:返回已经注册的数据流过滤器列表

stream_get_line函数:按照给定的定界符从数据流资源中获取行

stream_get_meta_data函数:从封装协议文件指针中获取报头/元数据

stream_get_transports函数:返回注册的Socket传输列表

stream_get_wrappers函数:返回注册的数据流列表

stream_register_wrapper函数:注册一个用PHP类实现的URL封装协议

stream_select函数:接收数据流数组并等待它们状态的改变

stream_set_blocking函数:将一个数据流设置为堵塞或者非堵塞状态

stream_set_timeout函数:对数据流进行超时设置

stream_set_write_buffer函数:为数据流设置缓冲区

stream_socket_accept函数:接受由函数stream_ socket_server()创建的Socket连接

stream_socket_client函数:打开网络或者UNIX主机的Socket连接

stream_socket_enable_crypto函数:为一个已经连接的Socket打开或者关闭数据加密

stream_socket_get_name函数:获取本地或者网络Socket的名称

stream_socket_pair函数:创建两个无区别的Socket数据流连接

stream_socket_recvfrom函数:从Socket获取数据,不管其连接与否

stream_socket_sendto函数:向Socket发送数据,不管其连接与否

stream_socket_server函数:创建一个网络或者UNIX Socket服务端

stream_wrapper_restore函数:恢复一个事先注销的数据包

stream_wrapper_unregister函数:注销一个URL地址包

整合资料

本文整合于以下两篇文章

PHP-php生成zip压缩文件如何给该文件加解压缩密码

?php

//需开启配置 php_zip.dll

//phpinfo();

header("Content-type:text/html;charset=utf-8");

function get_zip_originalsize($filename, $path) {

//先判断待解压的文件是否存在

if(!file_exists($filename)){

die("文件 $filename 不存在!");

$starttime = explode(' ',microtime()); //解压开始的时间

//将文件名和路径转成windows系统默认的gb2312编码,否则将会读取不到

$filename = iconv("utf-8","gb2312",$filename);

$path = iconv("utf-8","gb2312",$path);

//打开压缩包

$resource = zip_open($filename);

$i = 1;

//遍历读取压缩包里面的一个个文件

while ($dir_resource = zip_read($resource)) {

//如果能打开则继续

if (zip_entry_open($resource,$dir_resource)) {

//获取当前项目的名称,即压缩包里面当前对应的文件名

$file_name = $path.zip_entry_name($dir_resource);

//以最后一个“/”分割,再用字符串截取出路径部分

$file_path = substr($file_name,0,strrpos($file_name, "/"));

//如果路径不存在,则创建一个目录,true表示可以创建多级目录

if(!is_dir($file_path)){

mkdir($file_path,0777,true);

}

//如果不是目录,则写入文件

if(!is_dir($file_name)){

//读取这个文件

$file_size = zip_entry_filesize($dir_resource);

//最大读取6M,如果文件过大,跳过解压,继续下一个

if($file_size(1024*1024*6)){

$file_content = zip_entry_read($dir_resource,$file_size);

file_put_contents($file_name,$file_content);

}else{

echo "p ".$i++." 此文件已被跳过,原因:文件过大, - ".iconv("gb2312","utf-8",$file_name)." /p";

}

}

//关闭当前

zip_entry_close($dir_resource);

}

}

//关闭压缩包

zip_close($resource); 

$endtime = explode(' ',microtime()); //解压结束的时间

$thistime = $endtime[0]+$endtime[1]-($starttime[0]+$starttime[1]);

$thistime = round($thistime,3); //保留3为小数

echo "p解压完毕!,本次解压花费:$thistime 秒。/p";

}

$size = get_zip_originalsize('20131101.zip','temp/');

?

php怎样实现对zip文件的加密和解密

使用PHPZip类就可以解决的。以下是网上找到的例子。

$zipfiles =array("/root/pooy/test1.txt","/root/pooy/test2.txt");

$z = new PHPZip();

//$randomstr = random(8);

$zipfile = TEMP."/photocome_".$groupid.".zip";

$z-Zip($zipfiles, $zipfile);

?php

# PHPZip v1.2 by Sext (sext@neud点虐 ) 2002-11-18

#     (Changed: 2003-03-01)

# Makes zip archive

#

# Based on "Zip file creation class", uses zLib

#

#

class PHPZip

{

function Zip($dir, $zipfilename)

{

if (@function_exists('gzcompress'))

{    

$curdir = getcwd();

if (is_array($dir)) 

{

$filelist = $dir;

}

else 

{

$filelist = $this - GetFileList($dir);

}

if ((!empty($dir))(!is_array($dir))(file_exists($dir))) chdir($dir);

else chdir($curdir);

if (count($filelist)0)

{

foreach($filelist as $filename)

{

if (is_file($filename))

{

$fd = fopen ($filename, "r");

$content = fread ($fd, filesize ($filename));

fclose ($fd);

if (is_array($dir)) $filename = basename($filename);

$this - addFile($content, $filename);

}

}

$out = $this - file();

chdir($curdir);

$fp = fopen($zipfilename, "w");

fwrite($fp, $out, strlen($out));

fclose($fp);

}

return 1;

else return 0;

}

function GetFileList($dir)

{

if (file_exists($dir))

{

$args = func_get_args();

$pref = $args[1];

$dh = opendir($dir);

while($files = readdir($dh))

{

if (($files!=".")($files!="..")) 

{

if (is_dir($dir.$files)) 

{

$curdir = getcwd();

chdir($dir.$files);

$file = array_merge($file, $this - GetFileList("", "$pref$files/"));

chdir($curdir);

}

else $file[]=$pref.$files;

}

}

closedir($dh);

}

return $file;

}

var $datasec      = array();

var $ctrl_dir     = array();

var $eof_ctrl_dir = "x50x4bx05x06x00x00x00x00";

var $old_offset   = 0;

/**

* Converts an Unix timestamp to a four byte DOS date and time format (date

* in high two bytes, time in low two bytes allowing magnitude comparison).

*

* @param  integer  the current Unix timestamp

*

* @return integer  the current date in a four byte DOS format

*

* @access private

*/

function unix2DosTime($unixtime = 0) {

$timearray = ($unixtime == 0) ? getdate() : getdate($unixtime);

if ($timearray['year']  1980) {

$timearray['year']    = 1980;

$timearray['mon']     = 1;

$timearray['mday']    = 1;

$timearray['hours']   = 0;

$timearray['minutes'] = 0;

$timearray['seconds'] = 0;

} // end if

return (($timearray['year'] - 1980)  25) | ($timearray['mon']  21) | ($timearray['mday']  16) |

($timearray['hours']  11) | ($timearray['minutes']  5) | ($timearray['seconds']  1);

} // end of the 'unix2DosTime()' method

/**

* Adds "file" to archive

*

* @param  string   file contents

* @param  string   name of the file in the archive (may contains the path)

* @param  integer  the current timestamp

*

* @access public

*/

function addFile($data, $name, $time = 0)

{

$name     = str_replace('', '/', $name);

$dtime    = dechex($this-unix2DosTime($time));

$hexdtime = 'x' . $dtime[6] . $dtime[7]

. 'x' . $dtime[4] . $dtime[5]

. 'x' . $dtime[2] . $dtime[3]

. 'x' . $dtime[0] . $dtime[1];

eval('$hexdtime = "' . $hexdtime . '";');

$fr   = "x50x4bx03x04";

$fr   .= "x14x00";            // ver needed to extract

$fr   .= "x00x00";            // gen purpose bit flag

$fr   .= "x08x00";            // compression method

$fr   .= $hexdtime;             // last mod time and date

// "local file header" segment

$unc_len = strlen($data);

$crc     = crc32($data);

$zdata   = gzcompress($data);

$c_len   = strlen($zdata);

$zdata   = substr(substr($zdata, 0, strlen($zdata) - 4), 2); // fix crc bug

$fr      .= pack('V', $crc);             // crc32

$fr      .= pack('V', $c_len);           // compressed filesize

$fr      .= pack('V', $unc_len);         // uncompressed filesize

$fr      .= pack('v', strlen($name));    // length of filename

$fr      .= pack('v', 0);                // extra field length

$fr      .= $name;

// "file data" segment

$fr .= $zdata;

// "data descriptor" segment (optional but necessary if archive is not

// served as file)

$fr .= pack('V', $crc);                 // crc32

$fr .= pack('V', $c_len);               // compressed filesize

$fr .= pack('V', $unc_len);             // uncompressed filesize

// add this entry to array

$this - datasec[] = $fr;

$new_offset        = strlen(implode('', $this-datasec));

// now add to central directory record

$cdrec = "x50x4bx01x02";

$cdrec .= "x00x00";                // version made by

$cdrec .= "x14x00";                // version needed to extract

$cdrec .= "x00x00";                // gen purpose bit flag

$cdrec .= "x08x00";                // compression method

$cdrec .= $hexdtime;                 // last mod time  date

$cdrec .= pack('V', $crc);           // crc32

$cdrec .= pack('V', $c_len);         // compressed filesize

$cdrec .= pack('V', $unc_len);       // uncompressed filesize

$cdrec .= pack('v', strlen($name) ); // length of filename

$cdrec .= pack('v', 0 );             // extra field length

$cdrec .= pack('v', 0 );             // file comment length

$cdrec .= pack('v', 0 );             // disk number start

$cdrec .= pack('v', 0 );             // internal file attributes

$cdrec .= pack('V', 32 );            // external file attributes - 'archive' bit set

$cdrec .= pack('V', $this - old_offset ); // relative offset of local header

$this - old_offset = $new_offset;

$cdrec .= $name;

// optional extra field, file comment goes here

// save to central directory

$this - ctrl_dir[] = $cdrec;

} // end of the 'addFile()' method

/**

* Dumps out file

*

* @return  string  the zipped file

*

* @access public

*/

function file()

{

$data    = implode('', $this - datasec);

$ctrldir = implode('', $this - ctrl_dir);

return

$data .

$ctrldir .

$this - eof_ctrl_dir .

pack('v', sizeof($this - ctrl_dir)) .  // total # of entries "on this disk"

pack('v', sizeof($this - ctrl_dir)) .  // total # of entries overall

pack('V', strlen($ctrldir)) .           // size of central dir

pack('V', strlen($data)) .              // offset to start of central dir

"x00x00";                             // .zip file comment length

} // end of the 'file()' method

} // end of the 'PHPZip' class

?


本文标题:php数据流zip php输入流
网页链接:http://ybzwz.com/article/ddchgjd.html