关于php:PHP中的文件系统函数二

37次阅读

共计 8183 个字符,预计需要花费 21 分钟才能阅读完成。

这次咱们来学习的是一些不是太罕用,但却也十分有用的一些函数。它们中有些大家可能见过或者应用过,有一些可能就真的没什么印象了。它们都是 PHP 中文件系统相干操作函数的一部分。存在即正当,或者只是咱们的业务开发中还没有接触到而已。不论别的,先混个脸熟,在真正须要它们的时候你能马上想起来 PHP 就自带一个这样的函数就能够了。

目录判断、创立、删除、门路缓存信息

var_dump(is_dir("./")); // bool(true)
var_dump(disk_free_space("./")); // float(7727517696)
var_dump(disk_total_space("./")); // float(250790436864)

is_dir() 函数预计大家会比拟罕用,就是用来判断给定的门路是否存在或者是否失常。个别在手动创立目录之前都会应用这个函数来判断一下目录是否曾经创立过了,常见于上传相干的业务场景开发中。disk_free_space() 和 disk_total_space() 则是获取指定目录的残余磁盘空间和总的磁盘空间数据的函数。因为我的电脑是 Mac 零碎,所以总的磁盘空间就是 250G 的,可用的空间为 7G,看来马上就要筹备清理一下电脑了。

var_dump(mkdir("./a")); // bool(true)
var_dump(rmdir("./a"));  // bool(true)

mkdir() 函数用于创立一个目录,它除了给定的门路参数外,还有一个可选参数能够设置目录的文件权限,也是传递 0777 之类的值就能够了,这个函数置信大家不会很生疏,大部分的文件上传分目录的能力正是应用 is_dir() 来配合 mkdir() 进行目录创立的。rmdir() 是用于删除目录的,这个函数有两个前提,一是要删除的目录必须是空的,二是要有删除这个目录的权限,如果任一条件不满足的话,就会报出一个 E_WARNING 级别的谬误。

realpath('./');
var_dump(realpath_cache_get());
// array(8) {//     ["/Users/zhangyue/MyDoc/ 博客文章 /dev-blog/php/202010/source"]=>
//     array(4) {//       ["key"]=>
//       float(1.4990943845035E+19)
//       ["is_dir"]=>
//       bool(true)
//       ["realpath"]=>
//       string(61) "/Users/zhangyue/MyDoc/ 博客文章 /dev-blog/php/202010/source"
//       ["expires"]=>
//       int(1603327834)
//     }
//     ["/Users/zhangyue/MyDoc/ 博客文章"]=>
//     array(4) {//       ["key"]=>
//       int(8597410586338680)
//       ["is_dir"]=>
//       bool(true)
//       ["realpath"]=>
//       string(34) "/Users/zhangyue/MyDoc/ 博客文章"
//       ["expires"]=>
//       int(1603327834)
//     }
//     ["/Users"]=>
// ……
// ……

var_dump(realpath_cache_size()); // int(673)

realpath_cache_get() 函数用于获取实在目录缓存的详情,咱们须要先应用 realpath() 取得一个目录门路,而后就能够看到 realpath_cache_get() 外面的内容。能够看出它返回的数组中,是这条门路从第一个目录到这个目录中的所有目录信息,包含每一级目录的 realpath、is_dir 等属性信息。realpath_cache_size() 获取的是实在门路缓冲区的大小,也就是实在门路缓存区大小在内存中的使用量。

软连贯信息

上篇文章中咱们曾经学过了如何创立连贯文件,这次咱们再来看看两个小的对于连贯信息的函数。

var_dump(readlink('ltest2.txt')); // "test.txt"
var_dump(is_link('ltest2.txt')); // bool(true)

readlink() 函数用于取得软连贯所连贯到的实在文件的名称。在上篇文章中,咱们创立的 ltest2.txt 文件正是 test.txt 文件的软连贯。而 is_link() 函数则用于判断给定的文件是否是一个连贯文件。

拷贝、挪动、改名、删除文件操作

var_dump(copy('test.txt', 'cp_test.txt')); // bool(true)

var_dump(is_file("cp_test.txt")); // bool(true)

var_dump(move_uploaded_file('test.txt', 'mv_upload_test.txt')); // bool(false)
var_dump(is_file("mv_upload_test.txt")); // bool(false)
var_dump(is_uploaded_file("mv_upload_test.txt")); // bool(false)

var_dump(copy('test.txt', 're_test.txt')); // bool(true)
var_dump(rename('re_test.txt', 'new_re_test.txt')); // bool(true)

var_dump(copy('test.txt', 'del_test.txt')); // bool(true)
var_dump(unlink("del_test.txt")); // bool(true)

对于文件来说,copy() 是十分罕用的一个函数。不论是写代码还是日常办公,复制粘贴这样的拷贝操作都是咱们工作中的重心所在。PHP 提供的 copy() 函数就是专门用于文件拷贝的,不过须要留神的是,肯定要有文件和拷贝目标目录的读写权限哦。

move_uploaded_file() 文件置信大家也是十分相熟的,在上传文件的操作中也是常常会用到的一个性能。不过须要留神的是,从文件名就能够看出,move_uploaded_file() 的作用是挪动已上传文件,也就是 $_FILES 外面 tmp 中的文件,它是不能当做 copy() 函数来应用的。从演示代码中就能够看出,对于一般文件来说,它是无奈拷贝挪动的。is_uploaded_file() 函数就是用于判断要操作的文件是不是一个 PHP 已上传文件。

通过下面这两个函数,置信不少人都会想到文件上传中他们的应用,这里就给出一个简略的伪代码。

if(!move_uploaded_file('xxxx', 'xxxx')){if(copy('xxxx', 'xxxx')){// 上传胜利}else{// 上传失败}
}

很多教程里都会有这样的写法,甚至一些框架中也会有这样的写法。其实就是先应用 move_uploaded_file() 去挪动上传文件,如果失败了,再应用 copy() 函数拷贝一次。如果还是失败了,就认为整个上传操作失败了。

rename() 函数用于给文件改名,其实它就是相似于 Linux 零碎中的 mv 命令。

is_file() 函数用于判断给定的文件是否是一个失常的文件。在操作系统中,特地是 Linux 零碎中,所有皆文件,所以这个函数真正最罕用的场景是判断给定的门路到底是目录还是一个文件,很多时候咱们会用它来判断上传胜利后的文件是否失常,或者判断一个给定的门路到底是一个目录还是一个文件。

最初就是 unlink() 函数。在 PHP 中,没有 delete 或者 rm 这样的函数,unlink() 就是用于删除文件的。不过它的名字起得却像是要解除符号连贯文件的连贯一样,不论是连贯文件还是一般文件,都是通过这个 unlink() 函数来进行删除的。

文件一次性读取

对于文件一次性读取到内容和流式按字节或行来读取的内容咱们之前曾经有一篇文章具体的学习解说过,大家能够移步 PHP 大文件读取操作 中查看。所以这里咱们就简略的贴出代码演示一下。

var_dump(file_exists('test.txt')); // bool(true)
var_dump(readfile('test.txt')); // asdfasdfint(8)
var_dump(file('test.txt'));
// array(1) {//     [0]=>
//     string(8) "asdfasdf"
//   }

$c = file_get_contents('test.txt');
var_dump($c); // string(8) "asdfasdf"

var_dump(file_put_contents('fpc_test.txt', $c)); // int(8)

file_exists() 函数是业余的用于判断文件是否存在的函数,下面的 is_file() 会更多地用于上传之后的操作。而 file_exists() 则是在日常的代码编写中十分罕用的函数。readfile() 间接读取文件内容到内容中,file_get_contents() 也是这样的性能,只不过 file_get_contents() 返回的是以字符串为格局的文件内容。留神看咱们 var_dump() 的后果,file_get_contents() 显著的标了是 string(8) 这样的类型,而 readfile() 是间接输入内容,不走缓冲区的,也就是说它是相似于 phpinfo() 这样的函数。须要应用 ob_start() 之类的函数能力将 readfile() 函数读取的内容放到一个变量中,咱们之前的文章也专门讲过缓冲区的概念,PHP 中的输入缓冲管制。它的返回值是文件的字节数,也就是前面的 int(8)。

file() 函数是将文件的内容保留到一个数组中,它会默认以行进行分隔,也就是每一行分为数组中的一个元素。

file_put_contents() 是将给定的内容写入到一个文件中,和 file_get_contents() 配合也能够实现一个拷贝的操作。

文件属性

var_dump(fileatime('test.txt')); // int(1603243708)
var_dump(filectime('test.txt')); // int(1603242166)
var_dump(filemtime('test.txt')); // int(1603242166)

var_dump(fileinode('test.txt')); // int(8707958352)
var_dump(filesize('test.txt')); // int(8)
var_dump(filetype('test.txt')); // string(4) "file"

var_dump(is_executable('test.txt')); // bool(true)
var_dump(is_writable('test.txt')); // bool(true)
var_dump(is_readable('test.txt')); // bool(true)

很显著,fileatime()、filectime()、filemtime() 对应的就是文件的上次访问工夫、inode 批改工夫以及批改工夫,和 Linux 零碎中的文件相干的那三个工夫概念统一。fileinode() 用于取得文件的 inode 信息。filesize() 就是文件的大小,filetype() 是文件的类型信息。

is_executable() 用于判断文件是否能够执行,is_writable()、is_readable() 判断文件是否能够写和读。这三个函数对应的就是文件的权限相干的判断。

创立不重名文件及临时文件

var_dump(tempnam('./', 't_')); // string(70) "/Users/zhangyue/MyDoc/ 博客文章 /dev-blog/php/202010/source/t_Gx6S5d"


$temp = tmpfile();
fwrite($temp, "writing to tempfile");
fseek($temp, 0);
// sleep(30); // /tmp/phpU2LZ3V 文件
echo fread($temp, 1024), PHP_EOL; // writing to tempfile
fclose($temp); // 文件间接被删除了 

tempnam() 函数会依据指定的 prefix 参数来生成一个随机不重名的空文件。在测试代码中,咱们给定的 prefix 的值是 t_,最初生成的文件就是 t_Gx655d 这样一个空的文件。

tmpfile() 在之前的文章中也解说过,它是生成一个临时文件,个别会放在 /tmp 目录下(如果你没有批改 php.ini 文件中的相干设置的话)。这个函数创立文件后会返回一个句柄,一旦应用 fclose() 敞开了这个文件句柄,那么文件就马上会被删除掉。

按规定返回目录内容

foreach (glob("*.txt") as $filename) {echo "$filename size:" . filesize($filename) , PHP_EOL;
}
// cp_test.txt size 8
// fpc_test.txt size 8
// ltest.txt size 8
// ltest2.txt size 8
// new_re_test.txt size 8
// test.txt size 8
// test3.txt size 0

foreach (glob("../../202009/*.md") as $filename) {echo "$filename size:" . filesize($filename) , PHP_EOL;
}
// ./../202009/1.PHP 中的 PDO 操作学习(三)预处理类及绑定数据.md size:16881
// ../../202009/10.PHP 中十分好玩的 Calendar 扩大学习.md size:8784
// ../../202009/11. 学习 PHP 中的国际化性能来查看货币及日期信息.md size:5521
// ../../202009/12.PHP 中的日期相干函数(一).md size:14217
// ../../202009/13.PHP 中的日期相干函数(二).md size:9858
// ../../202009/2.PHP 中的 PDO 操作学习(四)查问构造集.md size:12825
// ../../202009/3. 在 PHP 中应用 SPL 库中的对象办法进行 XML 与数组的转换.md size:6068
// ../../202009/4.PHP 中的 MySQLi 扩大学习(一)MySQLi 介绍.md size:6029
// ../../202009/5.PHP 中的 MySQLi 扩大学习(二)mysqli 类的一些少见的属性办法.md size:9726
// ../../202009/6.PHP 中的 MySQLi 扩大学习(三)mysqli 的基本操作.md size:9403
// ../../202009/7.PHP 中的 MySQLi 扩大学习(四)mysqli 的事务与预处理语句.md size:3556
// ../../202009/8.PHP 中的 MySQLi 扩大学习(五)MySQLI_STMT 对象操作.md size:7450
// ../../202009/9.PHP 中的 MySQLi 扩大学习(六)MySQLI_result 对象操作.md size:10650

glob 函数也是之前有解说过的一个函数,它会依据指定的规定返回目录中的所有文件或者目录信息。能够不便地用于目录地遍历操作。留神这里的规定参数不是齐全的正则表达式,对于它具体反对的语法能够自行查阅相干的文档。

文件 umask 操作

$old = umask(0);
echo $old, PHP_EOL; // 18
$now = umask();
echo $now, PHP_EOL; // 0

umask() 函数就是操作以后执行过程的 umask 信息,和 Linux 中的 umask 命令一样,用于指定以后创立的目录文件的默认权限信息。在 PHP 中,umask() 将 PHP 的 umask 设定为 mask & 0777,并返回原来的 umask。当 PHP 被作为服务器模块应用时,在每个申请完结后 umask 会被复原。具体的 umask 常识大家能够参考 Linux 中的相干内容。

配置文件信息读取

最初这两个函数是用于读取 PHP 类型的配置文件信息的,什么叫 PHP 类型的配置文件信息?其实就是相似于 php.ini 文件那样的配置文件,key=value 这种模式的配置文件。就像 Laravel 的 .env 文件也是能够应用这两个函数进行读取的。

var_dump(parse_ini_file('/usr/local/etc/php/7.3/php.ini'));
// array(133) {//     ["#zend_extension"]=>
//     string(9) "xdebug.so"
//     ["extension"]=>
//     string(6) "vld.so"
//     ["engine"]=>
// ……
// ……

var_dump(parse_ini_file('/usr/local/etc/php/7.3/php.ini', true));
// array(38) {//     ["#zend_extension"]=>
//     string(9) "xdebug.so"
//     ["extension"]=>
//     string(6) "vld.so"
//     ["PHP"]=>
//     array(45) {//       ["engine"]=>
//       string(1) "1"
//       ["short_open_tag"]=>
// ……
// ……

parse_ini_file() 函数就是间接读取指定门路的配置文件内容,在这里咱们间接测试的就是读取 php.ini 文件。它有一个可选参数,如果设置为 true 的话,返回的就是数组分类的结构化的内容。

$ini = file_get_contents('/usr/local/etc/php/7.3/php.ini');
var_dump(parse_ini_string($ini));
// array(133) {//     ["#zend_extension"]=>
//     string(9) "xdebug.so"
//     ["extension"]=>
//     string(6) "vld.so"
//     ["engine"]=>
// ……
// ……

var_dump(parse_ini_string($ini, true));
// array(38) {//     ["#zend_extension"]=>
//     string(9) "xdebug.so"
//     ["extension"]=>
//     string(6) "vld.so"
//     ["PHP"]=>
//     array(45) {//       ["engine"]=>
//       string(1) "1"
//       ["short_open_tag"]=>
// ……
// ……

parse_ini_string() 则是从给定的字符串中读取配置信息,同样也有一个格式化分组输入的参数可选。它和 parse_ini_file() 是完全相同的,惟一的区别就是一个是从文件门路读取,一个是从字符串读取。

总结

一口气介绍了这么多函数,大家是不是都用过呢?有人要说了,写这玩意干嘛,间接去看文档不就好了嘛?那可不一样哦,文档中很多函数的介绍就一句话,示例代码也都是应用英文正文的,咱这虽说也是一个搬运工,但咱不仅是简略地搬运了一下,还把例子重写了,另外还加上了一些利用场景的介绍哦!至于各位看官感觉好不好,那就仁者见仁,智者见智咯!

测试代码:

https://github.com/zhangyue0503/dev-blog/blob/master/php/202010/source/7.PHP 中的文件系统函数(二).php

参考文档:

https://www.php.net/manual/zh/ref.filesystem.php

===========

各自媒体平台均可搜寻【硬核项目经理】

正文完
 0