php创建和删除目录函数介绍和递归删除目录函数分享

yipeiwu_com6年前PHP代码库

mkdir() — 新建目录

复制代码 代码如下:

– 语法:bool mkdir (string pathname [,int mode])
– 尝试新建一个由 pathname 指定的目录。

rmdir() — 删除目录
复制代码 代码如下:

– 语法:bool rmdir ( string dirname )
– 尝试删除 dirname 所指定的目录。 该目录必须是空的,而且要有相应的权限。如果成功则返回 TRUE,失败则返回
FALSE。

unlink — 删除文件
复制代码 代码如下:

– 语法:bool unlink ( string filename )
– 删除 filename。和 Unix C 的 unlink() 函数相似。如果成功则返回 TRUE,失败则返回 FALSE。

在PHP中,使用mkdir()函数只需要传入一个目录名即可很容易地建立一个新目录。但删除目录所使用的函数rmdir(),只能删除一个空目录并且目录必须存在。如果是非空的目录就需要先进入到目录中,使用unlink()函数将目录中的每个文件都删除掉,再回来将这个空目录删除。如果目录中还存在目录,而且子目录也非空,就要使用递归的方法了。自定义递归函数删除目录的程序代码如下所示:

复制代码 代码如下:

<?php
//自定义函数递归的删除整个目录
function delDir($directory){
    if(file_exists($directory)){      //如果不存在rmdir()函数会出错
        if($dir_handle = @opendir($directory)){       //打开目录,并判断是否能成功打开
            while($filename = readdir($dir_handle)){       //循环遍历目录下的所有文件
               if($filename != "."&& $filename != ".."){       //一定要排除两个特殊的目录
                   $subFile = $directory."/".$filename;       //将目录下的子文件和当前目录相连
                   if(is_dir($subFile))        //如果为目录则条件成立
                   delDir($subFile);       //递归地调用自身函数,删除子目录
                   if(is_file($subFile))      //如果是文件则条件成立
                   unlink($subFile);           //直接删除这个文件
               }
            }
            closedir($dir_handle); //关闭文件资源
            rmdir($directory); //删除空目录
         }
      }
}
 
dirDir("phpMyAdmin"); //调用delDir()函数,将程序所在目录中的“phpMyAdmin”文件删除
?>

当然也可以通过调用操作系统命令“rm-rf”删除非空的目录,但也要从安全和跨平台方面考虑尽量不要去使用。

相关文章

php获取网页内容方法总结

抓取到的内容在通过正则表达式做一下过滤就得到了你想要的内容,至于如何用正则表达式过滤,在这里就不做介绍了,有兴趣的,以下就是几种常用的用php抓取网页中的内容的方法。1.file_get...

PHP使用Redis替代文件存储Session的方法

PHP使用Redis替代文件存储Session的方法

本文实例讲述了PHP使用Redis替代文件存储Session的方法。分享给大家供大家参考,具体如下: PHP默认使用文件存储session,如果并发量大,效率非常低。而Redis对高并发...

php流量统计功能的实现代码

流量统计功能 显示效果: 总访问量:399 今日流量:14 昨日流量:16 本代码仅供学习交流,其中必有不妥之处。请见谅! -- -- 表的结构 `mycounter` -- 复制代码...

PHP数组递归排序实现方法示例

本文实例讲述了PHP数组递归排序实现方法。分享给大家供大家参考,具体如下: /** * 递归根据特定key对数组排序 * @param $data * @param strin...

PHP程序员编程注意事项

1.不转意html entities   一个基本的常识:所有不可信任的输入(特别是用户从form中提交的数据) ,输出之前都要转意。...