Web 在线文件管理器学习笔记与总结(6)jQuery UI 预览图片

① 查看文件内容,如果文件是图片类型,点击直接查看图片;

② 如果不是图片类型,显示文件中的内容;

③ 使用 jQuery UI 中的 Dialog 显示图片

a.引入:

<script src="jquery-1.8.3.min.js"></script>
<script src="jquery-ui-1.11.3/jquery-ui.min.js"></script>
<link rel="stylesheet" href="jquery-ui-1.11.3/jquery-ui.min.css" />

b.通过文件扩展名(或者MIME 类型)来判断是否是图片文件

index.php:

<?php
require ‘dir.func.php‘;
require ‘file.func.php‘;
require ‘common.func.php‘;
$path = ‘file‘;
$info = readDirectory($path);

$act = @$_REQUEST[‘act‘];
$filename = @$_REQUEST[‘filename‘];
//跳转变量
$redirect = "index.php?path={$path}";
if($act == ‘createFile‘){
    //创建文件
    $mes = createFile($path.‘/‘.$filename);
    alertMes($mes,$redirect);
}else if($act == ‘showContent‘){
//查看文件内容
    $content=file_get_contents($filename);
    //echo "<textarea readonly=‘readonly‘ cols=‘100‘ rows=‘10‘>{$content}</textarea>";
    //高亮显示PHP代码
    //高亮显示字符串中的PHP代码
    if(strlen($content)){
    $newContent=highlight_string($content,true);
    //高亮显示文件中的PHP代码
    //highlight_file($filename);
    $str=<<<EOF
    <table width=‘100%‘ bgcolor=‘pink‘ cellpadding=‘5‘ cellspacing="0" >
        <tr>
            <td>$newContent</td>
        </tr>
    </table>
EOF;
        echo $str;
    }else{
        alertMes("文件没有内容,请编辑再查看!",$redirect);
    }
}else if($act == ‘editContent‘){
    $content = file_get_contents($filename);
    $str=<<<EOF
    <form action=‘index.php?act=doEdit‘ method=‘post‘>
    <textarea name=‘content‘  cols=‘100‘ rows=‘10‘>$content</textarea></br>
    <input type=‘hidden‘ name=‘filename‘ value=‘{$filename}‘>
    <input type=‘submit‘ value=‘修改文件内容‘>
    </form>
EOF;
    echo $str;
}else if($act == ‘doEdit‘){
    //修改文件内容
    $content = $_POST[‘content‘];
    if(file_put_contents($filename, $content)){
        $mes = ‘文件修改成功‘;
    }else if(!$content){
        $mes = ‘文件内容被清空‘;
    }else{
        $mes = ‘文件修改失败‘;
    }
    alertMes($mes,$redirect);
}
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link rel="stylesheet" href="cikonss.css" />
<link rel="stylesheet" href="common.css" />
<script src="jquery-1.8.3.min.js"></script>
<script src="jquery-ui-1.11.3/jquery-ui.min.js"></script>
<link rel="stylesheet" href="jquery-ui-1.11.3/jquery-ui.min.css" />
</head>
<body>
<div id="showDetail" style="display:none"><img src="" alt="" id="showImg"></div>
<h1>在线文件管理器</h1>
<div id="top">
    <ul id="navi">
        <li><a href="index.php" title="主目录"><span style="margin-left: 8px; margin-top: 0px; top: 4px;" class="icon icon-small icon-square"><span class="icon-home"></span></span></a></li>
        <li><a href="#" onclick="show(‘createFile‘)" title="新建文件" ><span style="margin-left: 8px; margin-top: 0px; top: 4px;" class="icon icon-small icon-square"><span class="icon-file"></span></span></a></li>
        <li><a href="#" title="新建文件夹"><span style="margin-left: 8px; margin-top: 0px; top: 4px;" class="icon icon-small icon-square"><span class="icon-folder"></span></span></a></li>
        <li><a href="#" title="上传文件"><span style="margin-left: 8px; margin-top: 0px; top: 4px;" class="icon icon-small icon-square"><span class="icon-upload"></span></span></a></li>
        <li><a href="#" title="返回上级目录"><span style="margin-left: 8px; margin-top: 0px; top: 4px;" class="icon icon-small icon-square"><span class="icon-arrowLeft"></span></span></a></li>
    </ul>
</div>
<form action="index.php" method="post" enctype="multipart/form-data">
<table width=‘100%‘ border=‘1‘ cellpadding="5" cellspacing="0" bgcolor="#abcdef" align="center">
    <tr id="createFolder"  style="display:none;">
        <td>请输入文件夹名称</td>
        <td >
            <input type="text" name="dirname" />
            <input type="hidden" name="path"  value="<?php echo $path;?>"/>
            <input type="submit"  name="act"  value="创建文件夹"/>
        </td>
    </tr>
    <tr id="createFile"  style="display:none;">
        <td>请输入文件名称</td>
        <td >
            <input type="text"  name="filename" />
            <input type="hidden" name="path" value="<?php echo $path;?>"/>
            <input type="hidden" name=‘act‘ value=‘createFile‘/>
            <input type="submit" value="创建文件" />
        </td>
    </tr>
    <tr id="uploadFile" style="display:none;">
        <td >请选择要上传的文件</td>
        <td ><input type="file" name="myFile" />
            <input type="submit" name="act" value="上传文件" />
        </td>
    </tr>
    <tr align="center">
        <td>编号</td>
        <td>名称</td>
        <td>类型</td>
        <td>大小</td>
        <td>可读</td>
        <td>可写</td>
        <td>可执行</td>
        <td>创建时间</td>
        <td>修改时间</td>
        <td>访问时间</td>
        <td>操作</td>
    </tr>
    <?php
        if($info[‘file‘]){
            $i = 1;
            foreach($info[‘file‘] as $val){
                $p = $path.‘/‘.$val;
    ?>
    <tr align="center">
        <td><?php echo $i;?></td>
        <td><?php echo $val;?></td>
        <td><?php $src = filetype($p) == ‘file‘?‘file_ico.png‘:‘folder_ico.png‘;?><img src="images/<?php echo $src;?>" alt="" title=‘文件‘></td>
        <td><?php echo transByte(filesize($p));?></td>
        <td><?php $src = is_readable($p)?‘correct.png‘:‘error.png‘;?><img src="images/<?php echo $src;?>" width="32" alt="" title=‘可读‘></td>
        <td><?php $src = is_writeable($p)?‘correct.png‘:‘error.png‘;?><img src="images/<?php echo $src;?>" width="32" alt="" title=‘可写‘></td>
        <td><?php $src = is_executable($p)?‘correct.png‘:‘error.png‘;?><img src="images/<?php echo $src;?>" width="32" alt="" title=‘可写‘></td>
        <td><?php echo date(‘Y-m-d H:i:s‘,filectime($p));?></td>
        <td><?php echo date(‘Y-m-d H:i:s‘,filemtime($p));?></td>
        <td><?php echo date(‘Y-m-d H:i:s‘,fileatime($p));?></td>
        <td>
            <?php
                //得到文件扩展名
                $ext = strtolower(end(explode(‘.‘,$val)));
                $imageExt = array(‘gif‘,‘jpg‘,‘png‘,‘jpeg‘);
                if(in_array($ext, $imageExt)){ ?>
                <a href="javascript:void(0)" onclick=‘showDetail("<?php echo $val;?>","<?php echo $p;?>")‘ title=‘查看‘><img src="images/show.png" width="32" alt=""></a>

            <?php    }else{ ?>
                <a href="index.php?act=showContent&filename=<?php echo $p;?>" title=‘查看‘><img src="images/show.png" width="32" alt=""></a>
            <?php
                }
            ?>

            <a href="index.php?act=editContent&filename=<?php echo $p;?>" title=‘修改‘><img src="images/edit.png" width="32" alt=""></a>
            <a href="" title=‘重命名‘><img src="images/rename.png" width="32" alt=""></a>
            <a href="" title=‘复制‘><img src="images/copy.png" width="32" alt=""></a>
            <a href="" title=‘剪切‘><img src="images/cut.png" width="32" alt=""></a>
            <a href="" title=‘删除‘><img src="images/delete.png" width="32" alt=""></a>
            <a href="" title=‘下载‘><img src="images/download.png" width="32" alt=""></a>
        </td>
    </tr>
    <?php
                $i++;
            }
        }
    ?>
</table>
</form>
<script src=‘common.js‘></script>
</body>
</html>

c.在 common.js 文件中添加 showDetail() 方法

function show(dis){
    document.getElementById(dis).style.display = ‘block‘;
}

function showDetail(t,filename){
    $("#showImg").attr(‘src‘,filename);
    $("#showDetail").dialog({
        height:"auto",
        width:"auto",
        position:{my:"center",at:"center",collision:"fit"},
        modal:false,//是否模式对话框
        draggable:true,//是否允许拖拽
        resizable:true,//是否允许缩放
        title:t,//对话框标题
        show:"slide",
        hide:"explode"
    });
}

效果图:

时间: 2024-10-10 21:48:29

Web 在线文件管理器学习笔记与总结(6)jQuery UI 预览图片的相关文章

Web 在线文件管理器学习笔记与总结(19)上传文件

dir.func.php 中添加方法: /* 上传文件 */ function uploadFile($fileInfo,$path,$allowExt = array('jpg','jpeg','png','gif','txt'),$maxSize = 10487560){ //判断错误号 if($fileInfo['error'] == 0){ //文件是否是http上传上来的 if(is_uploaded_file($fileInfo['tmp_name'])){ $uniqid = md

Web 在线文件管理器学习笔记与总结(5)

① 读出要修改的文件的内容 ② 进行修改 ③ 将修改后的内容写进文件 index.php: <?php require 'dir.func.php'; require 'file.func.php'; require 'common.func.php'; $path = 'file'; $info = readDirectory($path); $act = @$_REQUEST['act']; $filename = @$_REQUEST['filename']; //跳转变量 $redire

Web 在线文件管理器学习笔记与总结(2)显示文件列表(名称,类型,大小,可读,可写,可执行,创建时间,修改时间,访问时间)

主要函数: filetype() 判断文件类型 filesize() 得到文件大小(字节) is_readable() 判断文件是否可读 is_writeable() 判断文件是否可写 is_executable() 判断文件是否可执行 filectime() 文件创建时间 filemtime() 文件修改时间 fileatime() 文件访问时间 file.func.php 封装文件操作的文件: <?php /* 转换字节大小 */ function transByte($size){ $ar

Web 在线文件管理器学习笔记与总结(13)重命名文件夹(14)复制文件夹

(13)重命名文件夹 ① 重命名文件夹通过 rename($oldname,$newname) 实现 ② 检测文件夹名是否符合规范 ③ 检测当前目录中是否存在同名文件夹名称,如果不存在则重命名成功 index.php: <?php require 'dir.func.php'; require 'file.func.php'; require 'common.func.php'; $path = 'file'; $path = @$_REQUEST['path'][email protected

Web 在线文件管理器学习笔记与总结(11)获取文件夹信息 (12)返回上一级操作

(11)获取文件夹信息 文件夹没有修改操作. index.php: <?php require 'dir.func.php'; require 'file.func.php'; require 'common.func.php'; $path = 'file'; $path = @$_REQUEST['path'][email protected]$_REQUEST['path']:$path; $info = readDirectory($path); if($info == NULL){ e

Web 在线文件管理器学习笔记与总结(4)查看文件内容

② 查看文件内容 a.通过 file_get_contents($filename) 得到文件内容 b.通过 highlight_string($string) 或者 highlight_file($filename) 显示内容.使用 PHP 内置的语法高亮器所定义的颜色,打印输出或者返回输出或者返回语法高亮版本的 PHP 代码 当使用 file_get_contents 读取(php)文件的内容并且显示在页面上,可以使用 <textarea></textarea> 包裹输出的内容

Web 在线文件管理器学习笔记与总结(1)初始文件以及获取首层目录信息

在线文件管理器即使用浏览器管理和操作项目中的目录和文件 文件相关操作包括: 1.创建文件 2.判断文件的权限 3.文件的大小 4.文件的创建时间.修改时间.访问时间 5.查看文件的内容 6.修改文件的内容 7.删除文件 8.重命名文件 9.复制文件 10.剪切文件 11.上传文件 12.下载文件 文件夹相关操作: 1.新建文件夹 2.判断文件夹的权限 3.文件夹的大小 4.文件夹的创建时间.修改时间.访问时间 5.查看文件夹的内容 6.重命名文件夹 7.复制文件夹 8.剪切文件夹 9.文件夹的下

Web 在线文件管理器学习笔记与总结(3)创建文件

① 创建文件 a. 文件名的合法性:不能包含 \/:*"<>| 等特殊字符 b. 检测当前目录下是否存在同名文件,如果存在提示请重命名后创建,如果不存在则直接创建 index.php: <?php require 'dir.func.php'; require 'file.func.php'; require 'common.func.php'; $path = 'file'; $info = readDirectory($path); $act = @$_REQUEST['a

Web 在线文件管理器学习笔记与总结(10)查看文件夹中的内容

① 读取文件夹大小 a. 封装计算文件夹大小的函数 b.  打开文件夹 c. 循环判断文件夹下的内容是文件还是文件夹,如果是文件,则累积相加文件的大小:如果是文件夹,则递归调用该函数 注意两个问题: a. 在计算每个文件夹大小之前,应该清空变量 $size,否则文件夹大小会累加(index.php) <td><?php $size = 0; echo transByte(dirSize($p));?></td> b. 在计算文件夹大小的方法中,$size 应该设置为全局