zoukankan      html  css  js  c++  java
  • php -- 文件操作类(文件或文件夹的:创建、删除、复制、移动)

    <? 
    /** 
    * 操纵文件类 
    * 
    * 例子: 
    * FileUtil::createDir('a/1/2/3'); 测试建立文件夹 建一个a/1/2/3文件夹 
    * FileUtil::createFile('b/1/2/3'); 测试建立文件 在b/1/2/文件夹下面建一个3文件 
    * FileUtil::createFile('b/1/2/3.exe'); 测试建立文件 在b/1/2/文件夹下面建一个3.exe文件 
    * FileUtil::copyDir('b','d/e'); 测试复制文件夹 建立一个d/e文件夹,把b文件夹下的内容复制进去 
    * FileUtil::copyFile('b/1/2/3.exe','b/b/3.exe'); 测试复制文件 建立一个b/b文件夹,并把b/1/2文件夹中的3.exe文件复制进去 
    * FileUtil::moveDir('a/','b/c'); 测试移动文件夹 建立一个b/c文件夹,并把a文件夹下的内容移动进去,并删除a文件夹 
    * FileUtil::moveFile('b/1/2/3.exe','b/d/3.exe'); 测试移动文件 建立一个b/d文件夹,并把b/1/2中的3.exe移动进去 
    * FileUtil::unlinkFile('b/d/3.exe'); 测试删除文件 删除b/d/3.exe文件 
    * FileUtil::unlinkDir('d'); 测试删除文件夹 删除d文件夹 
    */ 
    class FileUtil { 
    /** 
    * 建立文件夹 
    * 
    * @param string $aimUrl 
    * @return viod 
    */ 
    function createDir($aimUrl) { 
    $aimUrl = str_replace('', '/', $aimUrl); 
    $aimDir = ''; 
    $arr = explode('/', $aimUrl); 
    foreach ($arr as $str) { 
    $aimDir .= $str . '/'; 
    if (!file_exists($aimDir)) { 
    mkdir($aimDir); 
    } 
    } 
    } 
    /** 
    * 建立文件 
    * 
    * @param string $aimUrl 
    * @param boolean $overWrite 该参数控制是否覆盖原文件 
    * @return boolean 
    */ 
    function createFile($aimUrl, $overWrite = false) { 
    if (file_exists($aimUrl) && $overWrite == false) { 
    return false; 
    } elseif (file_exists($aimUrl) && $overWrite == true) { 
    FileUtil::unlinkFile($aimUrl); 
    } 
    $aimDir = dirname($aimUrl); 
    FileUtil::createDir($aimDir); 
    touch($aimUrl); 
    return true; 
    } 
    /** 
    * 移动文件夹 
    * 
    * @param string $oldDir 
    * @param string $aimDir 
    * @param boolean $overWrite 该参数控制是否覆盖原文件 
    * @return boolean 
    */ 
    function moveDir($oldDir, $aimDir, $overWrite = false) { 
    $aimDir = str_replace('', '/', $aimDir); 
    $aimDir = substr($aimDir, -1) == '/' ? $aimDir : $aimDir . '/'; 
    $oldDir = str_replace('', '/', $oldDir); 
    $oldDir = substr($oldDir, -1) == '/' ? $oldDir : $oldDir . '/'; 
    if (!is_dir($oldDir)) { 
    return false; 
    } 
    if (!file_exists($aimDir)) { 
    FileUtil::createDir($aimDir); 
    } 
    @$dirHandle = opendir($oldDir); 
    if (!$dirHandle) { 
    return false; 
    } 
    while(false !== ($file = readdir($dirHandle))) { 
    if ($file == '.' || $file == '..') { 
    continue; 
    } 
    if (!is_dir($oldDir.$file)) { 
    FileUtil::moveFile($oldDir . $file, $aimDir . $file, $overWrite); 
    } else { 
    FileUtil::moveDir($oldDir . $file, $aimDir . $file, $overWrite); 
    } 
    } 
    closedir($dirHandle); 
    return rmdir($oldDir); 
    } 
    /** 
    * 移动文件 
    * 
    * @param string $fileUrl 
    * @param string $aimUrl 
    * @param boolean $overWrite 该参数控制是否覆盖原文件 
    * @return boolean 
    */ 
    function moveFile($fileUrl, $aimUrl, $overWrite = false) { 
    if (!file_exists($fileUrl)) { 
    return false; 
    } 
    if (file_exists($aimUrl) && $overWrite = false) { 
    return false; 
    } elseif (file_exists($aimUrl) && $overWrite = true) { 
    FileUtil::unlinkFile($aimUrl); 
    } 
    $aimDir = dirname($aimUrl); 
    FileUtil::createDir($aimDir); 
    rename($fileUrl, $aimUrl); 
    return true; 
    } 
    /** 
    * 删除文件夹 
    * 
    * @param string $aimDir 
    * @return boolean 
    */ 
    function unlinkDir($aimDir) { 
    $aimDir = str_replace('', '/', $aimDir); 
    $aimDir = substr($aimDir, -1) == '/' ? $aimDir : $aimDir.'/'; 
    if (!is_dir($aimDir)) { 
    return false; 
    } 
    $dirHandle = opendir($aimDir); 
    while(false !== ($file = readdir($dirHandle))) { 
    if ($file == '.' || $file == '..') { 
    continue; 
    } 
    if (!is_dir($aimDir.$file)) { 
    FileUtil::unlinkFile($aimDir . $file); 
    } else { 
    FileUtil::unlinkDir($aimDir . $file); 
    } 
    } 
    closedir($dirHandle); 
    return rmdir($aimDir); 
    } 
    /** 
    * 删除文件 
    * 
    * @param string $aimUrl 
    * @return boolean 
    */ 
    function unlinkFile($aimUrl) { 
    if (file_exists($aimUrl)) { 
    unlink($aimUrl); 
    return true; 
    } else { 
    return false; 
    } 
    } 
    /** 
    * 复制文件夹 
    * 
    * @param string $oldDir 
    * @param string $aimDir 
    * @param boolean $overWrite 该参数控制是否覆盖原文件 
    * @return boolean 
    */ 
    function copyDir($oldDir, $aimDir, $overWrite = false) { 
    $aimDir = str_replace('', '/', $aimDir); 
    $aimDir = substr($aimDir, -1) == '/' ? $aimDir : $aimDir.'/'; 
    $oldDir = str_replace('', '/', $oldDir); 
    $oldDir = substr($oldDir, -1) == '/' ? $oldDir : $oldDir.'/'; 
    if (!is_dir($oldDir)) { 
    return false; 
    } 
    if (!file_exists($aimDir)) { 
    FileUtil::createDir($aimDir); 
    } 
    $dirHandle = opendir($oldDir); 
    while(false !== ($file = readdir($dirHandle))) { 
    if ($file == '.' || $file == '..') { 
    continue; 
    } 
    if (!is_dir($oldDir . $file)) { 
    FileUtil::copyFile($oldDir . $file, $aimDir . $file, $overWrite); 
    } else { 
    FileUtil::copyDir($oldDir . $file, $aimDir . $file, $overWrite); 
    } 
    } 
    return closedir($dirHandle); 
    } 
    /** 
    * 复制文件 
    * 
    * @param string $fileUrl 
    * @param string $aimUrl 
    * @param boolean $overWrite 该参数控制是否覆盖原文件 
    * @return boolean 
    */ 
    function copyFile($fileUrl, $aimUrl, $overWrite = false) { 
    if (!file_exists($fileUrl)) { 
    return false; 
    } 
    if (file_exists($aimUrl) && $overWrite == false) { 
    return false; 
    } elseif (file_exists($aimUrl) && $overWrite == true) { 
    FileUtil::unlinkFile($aimUrl); 
    } 
    $aimDir = dirname($aimUrl); 
    FileUtil::createDir($aimDir); 
    copy($fileUrl, $aimUrl); 
    return true; 
    } 
    }
    
    $fu = new FileUtil(); 
    $fu->moveFile('attachment/1301/thread/2_1_00edb4e36d915f7.jpg', 'imgupload/1301/thread/2_1_00edb4e36d915f7.jpg'); 
    ?>
  • 相关阅读:
    Oracle-连接多个字段
    Oracle-like 多条件过滤
    SQL-Union、Union ALL合并两个或多个 SELECT 语句的结果集
    EXCEL-批量删除筛选出的行,并且保留首行
    EXCEL-REPLACE()替换字符串最后几位 删除字符串最后几位
    Oracle-常用表的查询、增加列、删除列、修改列值功能【增删改查】
    Excel-返回列表或数据库中的分类汇总(汇总可以实现要还是不要统计隐藏行功能) subtotal()
    Excel-统计各分数段人数 frequency()
    Excel-给出指定数值的日期 date()
    Class类的理解与获取Class的实例
  • 原文地址:https://www.cnblogs.com/hf8051/p/4615592.html
Copyright © 2011-2022 走看看