溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP中有哪些文件系統(tǒng)函數(shù)

發(fā)布時(shí)間:2021-07-13 15:35:24 來源:億速云 閱讀:111 作者:chen 欄目:編程語言

這篇文章主要講解了“PHP中有哪些文件系統(tǒng)函數(shù)”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“PHP中有哪些文件系統(tǒng)函數(shù)”吧!

從這篇文章開始,我們將學(xué)習(xí)一系列的PHP文件系統(tǒng)相關(guān)函數(shù)。其實(shí)這些函數(shù)中,有很多都是我們經(jīng)常用到的,大家并不需要刻意地去記住它們,只要知道有這么個(gè)東西,在使用的時(shí)候記得來查文檔就可以了。

文件路徑相關(guān)函數(shù)

文件路徑相關(guān)的函數(shù)往往在一些框架中會(huì)比較常見,而且多會(huì)配合 \_\_FILE\_\_ 、 \_\_DIR\_\_ 之類的魔術(shù)常量使用。

echo "1) ".basename("/etc/sudoers.d", ".d"), PHP_EOL;
echo "2) ".basename("/etc/passwd"), PHP_EOL;
echo "3) ".basename("/etc/"), PHP_EOL;
echo "4) ".basename("."), PHP_EOL;
echo "5) ".basename("/"), PHP_EOL;
echo "6) ".basename("/usr/local/Cellar/php/7.3.9_1/README.md"), PHP_EOL;
// 1) sudoers
// 2) passwd
// 3) etc
// 4) .
// 5) 
// 6) README.md

basename() 函數(shù)是獲得路徑中的文件名,它有兩個(gè)參數(shù),第一個(gè)是文件的路徑,第二個(gè)是過濾掉的內(nèi)容,比如第一條測試語句我們過濾掉文件的后綴名。

echo "1) " . dirname("/etc/passwd") , PHP_EOL;
echo "2) " . dirname("/etc/") , PHP_EOL;
echo "3) " . dirname("."), PHP_EOL;
// 1) /etc
// 2) /
// 3) .

dirname() 返回的是路徑中的路徑部分,也就是不包含文件名的那部分內(nèi)容,和 basename() 正好是相反的功能。

print_r(pathinfo('/usr/local/Cellar/php/7.3.9_1/README.md'));
// Array
// (
//     [dirname] => /usr/local/Cellar/php/7.3.9_1
//     [basename] => README.md
//     [extension] => md
//     [filename] => README
// )

echo realpath('./../../..//../etc/passwd'), PHP_EOL;
// /private/etc/passwd

pathinfo() 函數(shù)用于以數(shù)組的形式返回路徑中的信息,從結(jié)果來看,我們可以看到文件的 dirname 部分,basename 部分,以及文件的擴(kuò)展名 extension 和不包含擴(kuò)展名的 filename 內(nèi)容。

realpath() 返回的是規(guī)范化的絕對路徑名,它擴(kuò)展所有的符號(hào)連接并且處理輸入的路徑中的 ./ 、 ../ 以及多余的 / ,返回的內(nèi)容是標(biāo)準(zhǔn)規(guī)范的絕對路徑。

修改文件所屬相關(guān)信息

接下來,我們學(xué)習(xí)一些修改文件相關(guān)屬性的函數(shù),主要就是在 Linux 系統(tǒng)環(huán)境中的文件權(quán)限信息的操作。

當(dāng)然,首先我們得創(chuàng)建一個(gè)文件。和 Linux 中的命令是非常類似的。

touch('test3.txt');

touch() 函數(shù)除了給出要?jiǎng)?chuàng)建的文件名之外,還有兩個(gè)可選參數(shù)可以指定文件的創(chuàng)建時(shí)間及訪問時(shí)間,不給參數(shù)的話默認(rèn)就是當(dāng)前時(shí)間。這個(gè)文件名可以是相對或絕對路徑中有權(quán)限的目錄,并在該目錄下創(chuàng)建一個(gè)空的文件。

echo fileowner('test.txt'), PHP_EOL; // 501
chown('test.txt', 'www');
clearstatcache();
echo fileowner('test.txt'), PHP_EOL; // 70

通過 fileowner() 函數(shù),我們可以獲得某個(gè)文件所屬的用戶,默認(rèn)情況下我們的用戶是當(dāng)前運(yùn)行 PHP 腳本的用戶,也就是系統(tǒng)目前的登錄用戶。

在這里,我們使用 chown() 函數(shù),將用戶改為 www 用戶。clearstatcache() 是用于清理文件系統(tǒng)的緩存信息,如果不清理一下的話,fileowner() 返回的依然還是之前的用戶信息。

echo filegroup('test.txt'), PHP_EOL; // 20
chgrp('test.txt', 'www');
clearstatcache();
echo filegroup('test.txt'), PHP_EOL; // 70

echo substr(sprintf('%o', fileperms('test.txt')), -4), PHP_EOL; // 0766
chmod('test.txt', 0777);
clearstatcache();
echo substr(sprintf('%o', fileperms('test.txt')), -4), PHP_EOL; // 0777

同理,使用 filegroup() 函數(shù)獲得文件的屬組信息,chgrp() 用于修改文件的屬組。fileperms() 用于返回文件的權(quán)限信息,它返回的是數(shù)字模式的文件訪問權(quán)限,這里我們使用 sprintf() 格式化結(jié)果后獲得我們常用的 Linux 系統(tǒng)權(quán)限格式。

chmod() 函數(shù)用于修改文件的權(quán)限,它的權(quán)限參數(shù)是三個(gè) 8 進(jìn)制數(shù)據(jù)組成的數(shù)字,也就是代表 Linux 系統(tǒng)中的 1 、2 、4 和它們的組合,所以我們需要在前面再加上一個(gè) 0 用于確保操作能夠正常執(zhí)行。關(guān)于系統(tǒng)文件權(quán)限的知識(shí)大家需要認(rèn)真學(xué)習(xí) Linux 系統(tǒng)中相關(guān)的內(nèi)容。

注意,上述函數(shù)如果在命令行中運(yùn)行失敗,大部分原因是沒有權(quán)限,可以使用 sudo 進(jìn)行測試。在 fastcgi 中運(yùn)行時(shí),就更加需要注意權(quán)限問題,僅在我們服務(wù)器可以操作的目錄中進(jìn)行安全的文件權(quán)限修改。

print_r(stat('test.txt'));
// Array
// (
//     [0] => 16777220
//     [1] => 8707958352
//     [2] => 33279
//     [3] => 2
//     [4] => 70
//     [5] => 70
//     [6] => 0
//     [7] => 0
//     [8] => 1603070453
//     [9] => 1603070453
//     [10] => 1603072836
//     [11] => 4096
//     [12] => 0
//     [dev] => 16777220
//     [ino] => 8707958352
//     [mode] => 33279
//     [nlink] => 2
//     [uid] => 70
//     [gid] => 70
//     [rdev] => 0
//     [size] => 0
//     [atime] => 1603070453
//     [mtime] => 1603070453
//     [ctime] => 1603072836
//     [blksize] => 4096
//     [blocks] => 0
// )

stat() 函數(shù)可以獲取到指定文件的所有屬性信息,在這里我們可以看到文件的 uid 、 gid 、 ctime 、 mtime 等信息。

軟硬文件連接相關(guān)操作

在 Linux 系統(tǒng)中,有軟連接和硬連接的相關(guān)知識(shí)。其實(shí)軟連接就像是 Windows 中的快捷方式,而硬連接相關(guān)于復(fù)制了一份數(shù)據(jù)。在 PHP 中,也為我們提供了創(chuàng)建軟硬連接以及相關(guān)的一些操作。

link('test.txt', 'ltest.txt');
echo linkinfo('ltest.txt'), PHP_EOL; // 16777220

symlink('test.txt', 'ltest2.txt');
echo linkinfo('ltest2.txt'), PHP_EOL; // 16777220

print_r(lstat('ltest2.txt'));
// Array
// (
//     [0] => 16777220
//     [1] => 8707962848
//     [2] => 41453
//     [3] => 1
//     [4] => 0
//     [5] => 20
//     [6] => 0
//     [7] => 8
//     [8] => 1603072717
//     [9] => 1603072717
//     [10] => 1603072717
//     [11] => 4096
//     [12] => 0
//     [dev] => 16777220
//     [ino] => 8707962848
//     [mode] => 41453
//     [nlink] => 1
//     [uid] => 0
//     [gid] => 20
//     [rdev] => 0
//     [size] => 8
//     [atime] => 1603072717
//     [mtime] => 1603072717
//     [ctime] => 1603072717
//     [blksize] => 4096
//     [blocks] => 0
// )

使用 link() 函數(shù)創(chuàng)建的就是一個(gè)指定文件的硬連接文件,而使用 symlink() 創(chuàng)建的則是一個(gè)軟連接文件。相對來說,我們使用軟連接的場景會(huì)更多一些。lstat() 就和 stat() 函數(shù)的功能一樣,查看文件的各種屬性信息,不過 lstat() 函數(shù)針對的是軟硬連接文件。

lchown('ltest2.txt', 'zhangyue');
lchgrp('ltest2.txt', 'staff');
// lrwxr-xr-x  1 zhangyue  staff      8 Oct 19 09:58 ltest2.txt -> test.txt

同樣地,我們也可以修改軟硬連接的用戶和用戶組信息,不過它們的信息不能通過 fileowner() 或 filegroup() 查看。因?yàn)樗鼈兪沁B接文件,本身還是和原始文件綁定在一起的,使用 fileowner() 這類的函數(shù)查看到的依然是原始文件的信息。我們可以在系統(tǒng)環(huán)境中使用 ls -l 查看連接文件的用戶和用戶組信息是否修改成功。

總結(jié)

今天的內(nèi)容比較簡單,而且修改權(quán)限的操作也并不常用。不過對于系統(tǒng)安全來,它們還是非常有用的,比如對于上傳來說,我們要預(yù)防上傳可執(zhí)行文件的話,就可以通過修改文件的權(quán)限來讓文件無法直接運(yùn)行,從而起到安全保護(hù)的作用。

另外,目錄路徑相關(guān)的操作也是一些框架的基礎(chǔ),幾乎所有框架的入口或者說是 Composer 的入口,都會(huì)見到 dirname() 以及 basename() 之類函數(shù)的身影。

測試代碼:

https://github.com/zhangyue0503/dev-blog/blob/master/php/202010/source/6.PHP中的文件系統(tǒng)函數(shù)(一).php

感謝各位的閱讀,以上就是“PHP中有哪些文件系統(tǒng)函數(shù)”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對PHP中有哪些文件系統(tǒng)函數(shù)這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI