/**
* (thinkPHP)压缩文件夹下的多个文件并下载
* 不支持创建多个文件夹==有空完善
* @date: 2017-6-27 下午4:01:57
*/
function zipDowload($filename=''){
$export_url = C('PERFOR_EXPORT_FOLDER');
$download_url = C('XLS_DOWLOAD');
//删除原有文件
clear_folder($download_url);
$download_url = $download_url.'/'.$filename.'.zip';
$zip=new \ZipArchive();
$download_file = array();
$handler = opendir($export_url);
while(($name = readdir($handler)) !== false ) {
if($name != '.' && $name != '..') {
$name = iconv('gb2312','utf-8',$name);
$tag = explode('.', $name);
if($tag[count($tag)-1] == 'xlsx' || $tag[count($tag)-1] == 'xls'){
$download_file[] = $export_url.'/'.$name;
}
}
}
//解决Linux下中文字符文件名问题
$download_url = iconv("utf-8", "GB2312//IGNORE", $download_url);
//生成并打开zip
$res = $zip->open($download_url, \ZipArchive ::CREATE);
if($res === TRUE) {
foreach ($download_file as $v) {
$v = iconv("utf-8", "GB2312//IGNORE", $v);
$zip->addFile($v,$this->get_basename($v));
//unlink($v);
}
$zip->close();
clear_folder($export_url);
$xls_download = C('XLS_DOWLOAD_GET');
$url = $xls_download . '/'.$filename.'.zip';
if(strtoupper(substr(PHP_OS,0,3)) !== 'WIN'){
$url = iconv("utf-8", "GB2312//IGNORE", $url);
}
if(file_exists($download_url)){
header('location:'.$url);
}
}else{
exit('无法创建zip文件');
}
}
/**
* 获取文件名
* @date: 2017-6-27 下午5:57:55
*/
public function get_basename($filename){
return preg_replace('/^.+[\\/]/', '', $filename);
}
* (thinkPHP)压缩文件夹下的多个文件并下载
* 不支持创建多个文件夹==有空完善
* @date: 2017-6-27 下午4:01:57
*/
function zipDowload($filename=''){
$export_url = C('PERFOR_EXPORT_FOLDER');
$download_url = C('XLS_DOWLOAD');
//删除原有文件
clear_folder($download_url);
$download_url = $download_url.'/'.$filename.'.zip';
$zip=new \ZipArchive();
$download_file = array();
$handler = opendir($export_url);
while(($name = readdir($handler)) !== false ) {
if($name != '.' && $name != '..') {
$name = iconv('gb2312','utf-8',$name);
$tag = explode('.', $name);
if($tag[count($tag)-1] == 'xlsx' || $tag[count($tag)-1] == 'xls'){
$download_file[] = $export_url.'/'.$name;
}
}
}
//解决Linux下中文字符文件名问题
$download_url = iconv("utf-8", "GB2312//IGNORE", $download_url);
//生成并打开zip
$res = $zip->open($download_url, \ZipArchive ::CREATE);
if($res === TRUE) {
foreach ($download_file as $v) {
$v = iconv("utf-8", "GB2312//IGNORE", $v);
$zip->addFile($v,$this->get_basename($v));
//unlink($v);
}
$zip->close();
clear_folder($export_url);
$xls_download = C('XLS_DOWLOAD_GET');
$url = $xls_download . '/'.$filename.'.zip';
if(strtoupper(substr(PHP_OS,0,3)) !== 'WIN'){
$url = iconv("utf-8", "GB2312//IGNORE", $url);
}
if(file_exists($download_url)){
header('location:'.$url);
}
}else{
exit('无法创建zip文件');
}
}
/**
* 获取文件名
* @date: 2017-6-27 下午5:57:55
*/
public function get_basename($filename){
return preg_replace('/^.+[\\/]/', '', $filename);
}