显示文件用到的函数有

1、urlencode($str):编码URL字符串,便于将字符串编码并将其用于URL的请求部分

2、urldecode($str):解码已经编码的URL字符串,返回解码后的字符串

3、iconv('GB2312','UTF-8',$str):将字符串$str,编码由GB2312转变为utf-8;解决中文乱码

4、file_exists($path):检查文件或目录是否存在,$path规定要检查的路径

5、stripos($str,$find,$start):查找$find,在字符串中第一次出现的位置,没找到返回false

6、chdir(directory):directory规定新的当前目录

7、getcwd():获取当前目录

8、opendir($path):打开文件,$path要打开的目录路径

9、readdir(dir_handle):函数返回目录中下一个文件的文件名(如:文件夹中的文件名),dir_handle,可选,指定之前有opendir()打开的目录句柄资源

10、filesize($filename):返回指定文件的大小

11、filectime($filename):返回指定文件的创建时间

12、filemtime($filename):返回指定文件的最后修改时间

13、array_column($arr,$column_key):$column_key,需要返回的列,可以是索引数组的整数索引,或者是关联数组的列的字符串键值,也可以是null;PHP版本要5.5+

14、array_multisort($arr,sorting order,sorting type):函数返回排序数组,sorting order规定排列顺序(SORT_ASC升序【A-Z】,SORT_DESC降序【Z-A】)

15、is_dir():检查指定的文件是否是目录

public function index($currdir=null){

  //解决中文文件乱码

  $currdir = urldecode($currdir);

  $currdir = iconv('UTF-8','GB2312',$currdir);

  if($currdir){

    //判断目录是否存在

    if(file_exists($currdir)){

      //查看权限,最大权限是项目根目录

      if(stripos($currdir,ROOT_PATH) === 0 && stripos($currdir,ROOT_PATH,'..') === false){

        chdir($currdir);//$currdir 规定新的当前目录(打开目录,如:查看子目录、上级目录)

      }

    }

  }

  $rootdir = getcwd();//获取当前路径

  $dir = opendir($rootdir);//打开文件

  $data = [];

  $num['dir'] = 0;

  $num['file'] = 0;

  //循环读取文件

  while($filename = readdir($dir)){

    if($filename !='.' && $filename !='..'){//显示目录到页面不要上级目录‘..’和当前目录‘.’

      if(is_dir($filename)){

        $arr['icon'] = '#icon-mulu';//输出目录图标

        $arr['flag'] = 1;//标记是否是目录

        $num['dir']++;//记录目录的数量

      }else{

        $arr['icon'] = '#icon-wenjian';//输出文件图标

        $arr['flag'] = 1;//判断是否是文件

        $num['file'] ++;//记录文件的数量

      }

      $arr['currdir'] = iconv('GB2312','UTF-8',getcwd().'\\'.$filename);

      $arr['name'] = $filename;//文件名

      $arr['size'] = filesize($filename);//文件大小

      $arr['ctime'] = filectime($filename);//文件创建时间

      $arr['mtime'] = filemtime($filename);//文件最后修改时间

      $data[] = $arr;

    }

  }

  //对文件和文件夹分类排序

  array_multisort(array_column($data,'flag'),SORT_DESC,$data);

  $this->assign('dirs',$data);

  return view();

}

/**
* 文件大小转换(B、KB、MB、TB)显示
*/
function size_format($size = 0, $num = 0)
{
$unit = ['B', 'KB', 'MB', 'TB'];
$i = 0;
while ($size > 1024) {
$size /= 1024;//$size = $size/1024
$i++;
}
return round($size, $num) . $unit[$i];//round()保留小数点
}

HTML模板

<tbody>
{volist name="dirs" id="v"}
<tr>
<td class="fileicon">
<svg class="my-icon" aria-hidden="true">
<use xlink:href="{$v.icon}"></use>
</svg>
<a href="{$v.flag?'?currdir='.$v.currdir:'javascript:;'}">{$v.name|iconv='GB2312','UTF-8',###}</a>
</td>
<td>{$v.flag?"文件夹":size_format($v.size,1)}</td>
<?php $p=urlencode($v['currdir']);?>
<td>{$p|getpics=###,40}</td>
<td>{$v.ctime|date="Y-m-d",###}</td>
<td>{$v.mtime|date="Y-m-d",###}</td>
<td>
<span class="cz">
      <a class="filelink" href="javascript:;" onclick="DeleteFile('{$v.currdir|urlencode=###}')">删除</a> |       {eq name="v.flag" value="0"}
      <a class="filelink" href="{:url('file/edit')}?file={$v.currdir|urlencode=###}" >编辑</a> |
      {/eq}
      <a class="filelink" href="javascript:;" onclick="ReName('{$v.currdir|urlencode=###}','{$v.currdir|basenamecn=###}')">重命名</a>
{eq name="v.flag" value="0"}
|<a class="filelink" href="{:url('file/download')}?currdir={$v.currdir|urlencode=###}">下载</a>
{/eq}       </span>
</td>
</tr>
{/volist}
</tbody>

PHP、thinkPHP5.0开发网站文件管理功能(一)显示文件的更多相关文章

  1. PHP、thinkPHP5.0开发网站文件管理功能(三)重命名文件

    public function renames(){ if(request()->isAjax()){ $file = iconv('UTF-8','GB2312',urldecode(inpu ...

  2. PHP、thinkPHP5.0开发网站文件管理功能(二)删除文件

    1.is_dir():检查指定的文件是否是目录 2.scandir():返回指定目录中的文件和目录数组 3.unlink():删除文件,如果删除的文件不存在会报错,加@抑制报错 public func ...

  3. PHP、thinkPHP5.0开发网站文件管理功能(四)下载文件

    public function download($currdir = null){ $file = urldecode($currdir); $file = iconv('UTF-8', " ...

  4. PHP、thinkPHP5.0开发网站文件管理功能(三)编辑文件

    public function edit(){ $file = iconv('UTF-8','GB2312',urldecode(input('file'))); if(empty($file)|| ...

  5. ThinkPHP5.0 开发手册

    ThinkPHP5.0开发手册地址 https://www.kancloud.cn/manual/thinkphp5/118003 此博文仅仅作为个人笔记存储,没有广告,宣传的意图

  6. 微信公众号php从0开发,包括功能(自定义菜单,分享)

    之前写的一篇微信公众号文章. 工作需要,进行此次调研,并记录开发过程. 开发目的,页面授权,页面获取用户头像,用户昵称 微信id, 分享页面. 微信订阅号 无法获取用户个人信息 写在记录前,公众号也是 ...

  7. thinkphp5.0开发规范

    命名规范 ThinkPHP5遵循PSR-2命名规范和PSR-4自动加载规范,并且注意如下规范: 目录和文件 目录不强制规范,驼峰及小写+下划线模式均支持: 类库.函数文件统一以.php为后缀: 类的文 ...

  8. Thinkphp5.0实战开发二------自动生成目录结构

    序言 ThinkPHP5.0 具备自动创建功能,可以用来自动生成需要的模块及目录结构和文件等,自动生成主要调用\think\Build 类库.ThinkPHP5.0中模块文件夹在application ...

  9. ThinkPHP5.0框架开发--第4章 TP5.0路由

    ThinkPHP5.0框架开发--第4章 TP5.0路由 第4章 TP5.0 路由 ================================================== 上次复习 1. ...

随机推荐

  1. 高性能MySQL笔记-第5章Indexing for High Performance-003索引的作用

    一. 1. 1). Indexes reduce the amount of data the server has to examine.2). Indexes help the server av ...

  2. noi.ac day1t3 Sort

    传送门 分析 快排的原理是以任意一个数为标准,然后把所有小于它的数换到它的左边,所有大于它的数换到它的右边.我们就使用快排的思路,分治整个区间.对于每个区间以排好序的这个数列的中间位置的值为标准,然后 ...

  3. WordCount测试小程序的实现

    一.GitHub地址: https://github.com/245553473/WordCount 二.PSP表格: PSP PSP阶段 预估耗时(分钟) 实际耗时(分钟) Planning 计划 ...

  4. Java多线程并发学习-进阶大纲

    1.synchronized 的实现原理以及锁优化? 2.volatile 的实现原理? 3.Java 的信号灯? 4.synchronized 在静态方法和普通方法的区别? 5.怎么实现所有线程在等 ...

  5. Required plugin could not be found. Videos requires to install plugins to play files of the following types : MPEG-4-AAC decoder and H.264 decoder

    https://linuxconfig.org/how-to-install-mpeg-4-aac-decoder-for-centos-7-linux 记得联网情况下才能下载.

  6. 事件Event 介绍总结

    最近在总结一些基础的东西,主要是学起来很难懂,但是在日常又有可能会经常用到的东西.前面介绍了 C# 的 AutoResetEvent的使用介绍, 这次介绍事件(event). 事件(event),对于 ...

  7. 使用metasploit进行栈溢出攻击-5

    我们先尝试使用这个脚本进行攻击: msf > use exploit/linux/myvictim msf exploit(myvictim) > set payload linux/x8 ...

  8. centoOS下安装python3 和 pip: command not found

    在更新python3的时候会自动安装pip3,但是安装完成后,pip -V发现出错:command not found,找了好久,发现在建立软连接的时候路径写错了. 总结一下安装python3和发现p ...

  9. Python3中的Json与Pickle

    用于将数据存取到文件中: 1:Json的存数据到文件: import json info = { "name":"hjc", "age":2 ...

  10. Hawk-and-Chicken 强连通

    题意:一群人投票  票具有传递性  求出累计和最大的数和 哪几个人最大 强连通好题!!! 毫无疑问先强连通缩点 一开始打算拓扑排序求dis  但是发现拓扑排序会有重复累加的情况 那么就反向建图   当 ...