1.16 文件管理

简单的查看文件功能,文件中的文件和文件夹都显示,双击文件夹可以显示下一级子目录,双击“返回上一级”可以返回到上一级目录

1.先将需要管理的文件遍历出来

<?php   
  //打开目录资源
  $dir = opendir($fname); 
             
  //循环读取
  while($n = readdir($dir))  
  {  <br>    //拼个路径
    $url = $fname."/".$n;<br>    //没有这个条件,会有./..的这个路径
    if($n!="." && $n!="..")
    {
      if(is_dir($url))   //判断路径是不是目录
     {
       echo "<div class='file mulu' lj='{$url}' >{$n}</div>";  //如果是目录,就进这个,起个名字,双击这个进入下一个子目录
     } 
     else
     {
       echo "<div class='file' lj='{$url}'>{$n}</div>";   //如果不是目录,就进入这个。。统一的起个名字,这样好给他们写样式
     }
    }
                     
  }
  closedir($dir);  //关闭目录资源
?>

 

给遍历出来的目录和文件加样式 ,上面已将给他们起了名字了(样式可以随便换)

<style type="text/css">
    *{margin:0px auto; padding:0px}
    .file{ width:50%; height:30px; border:1px solid #60F}
    .mulu{ color:#FFF}
         
</style>

 

2.对遍历出来的文件中的目录加事件(双击这个目录打开子目录)

<script type="text/javascript"><br>     //找到这个目录,然后加双击事件
    $(".mulu").dblclick(function(){  
    var url = $(this).attr("lj");  //点击这个目录,找到这个目录的路径
    $.ajax({ 
        url:"wjcl.php",  //编写处理页面
        data:{url:url},  //将路径传到处理页面
        type:"POST",  //传值方式
        dataType:"TEXT",
        success: function(data){
            window.location.href = "file_homework.php";  //刷新页面
          }
                         
      })
    })
</script>

 

3.处理页面的编写(这里不能用post或是get传值了,可以用session传值方式传值)  

<?php
session_start();  //开启session
$url = $_POST["url"];  //接收上面传过来的url值
$_SESSION["url"]=$url; //session方式的值等于传的url值

 

4.处理页面结束后,也要在主页面开启session,还要判断传值是否为空,因为刚开始管理页面时没有“返回上一级”,所以要判断

//要写在php的最顶端
session_start();
 
//这个要写在“打开目录资源的上面”                     
if(!empty($_SESSION["url"]))
{
    $fname = $_SESSION["url"];
}

 

5.输出“返回上一级”的div

$jdlj = realpath($fname);  //文件的绝对路径
if($jdlj == "D:\\wamp\\www\\ajax")
{  //如果路径相等就为空 
}
else
{
    $fuji = dirname($fname); //否则就输出没有文件名的路径
    echo "<div class='file prev' lj='{$fuji}' >返回上一级</div>";  //输出这个div
}

 

6.有了这一栏,就可以利用这一栏进行返回上一级目录了,可以给这个div加双击事件

$(".prev").dblclick(function(){
    var url = $(this).attr("lj");  //找到这个div<br>     //处理页面和遍历目录时的处理页面是一样的
    $.ajax({
        url:"wjcl.php",
        data:{url:url},
        type:"POST",
        dataType:"TEXT",
        success: function(data){
        window.location.href = "file_homework.php";  //刷新页面
            }
    })
})

 

二、再进一步管理一下文件,新建文件在这个文件夹中  

1.就是写个文本框,在添加个新建按钮

<input type="text" id="name" />  //文本框:起名字用的
<input type="button" value="新建" id="new" />  //新建按钮

 

2.给按钮写单击事件

$("#new").click(function(){
    var name = $("#name").val();
    $.ajax({
        url:"newcl.php",
        data:{name:name},
        type:"POST",
        dataType:"TEXT",
        success: function(d){
        window.location.href = "file_homework.php";   //刷新页面               
            }
    })         
})         

 

3.新建文件的处理页面

<?php
session_start();  //开启session
$name = $_POST["name"];  //获取传递过来的名字
 
$url = $_SESSION["url"];  //保存的路径位置
 
$filename = $url."/".$name;  //拼保存路径
 
touch($filename);  //新建文件方法touch()
?>

 

三、下一个管理功能,删除不想要的文件

1.添加删除按钮,在遍历文件那添加删除按钮

echo "<div class='file' lj='{$url}'>{$n}<input type='button' value='删除' lj='{$url}' id='delete'/></div>"; //起个名字,给他添加样式,可以让他好看一点,也是为了后面的添加事件

 

添加的样式:

#delete{ float:right}   //浮动

 

 

2.给按钮添加单击事件

$(".delete").click(function(){
    var lj = $(this).attr("lj");  //找到删除的文件的路径
    $.ajax({
        url:"deletecl.php",  //编写删除的处理页面
        data:{lj:lj},
        type:"POST",
        dataType:"TEXT",
        success: function(a){
            window.location.href = "file_homework.php";  //刷新页面            
        }
    })
})

 

3.找到这个传值,用删除文件方法删除

<?php
$lj = $_POST["lj"];
unlink($lj);  //删除文件的方法unlink()
?>

 

posted @ 2017-01-17 08:47  风华~~  阅读(262)  评论(0编辑  收藏  举报