PHP的檔案權限有哪些類型? PHP下Linux下執行檔時的檔案權限有哪些方法?下面這篇文章我將跟大家分享一下關於PHP在Linxu下執行時的檔案權限方法。
一、檔案權限及所屬
1、檔案有三種類型的權限,為了方便期間,可以用數字來代替,這樣可以透過數字的加減,用一個數字就能標識這個檔案的權限了,例如7=4 2 1,表示讀寫執行3個權限都有,6=4 2,表示有讀寫權限沒有執行權限等等
2、聯想web應用的rbac權限管理等,linux下同樣有使用者權限的管理,使用者有使用者名稱和使用者群組,一般建立使用者時同時會建立同名的使用者所屬群組。
先root帳號登入隨便新建一個目錄和一個檔案
#新建目录 mkdir abc #新建文件 touch abc.txt #查看 ls -all
查看時會發現:
#d开头的为目录,-开头为文件,还有l开头的为连接等 drwxr-xr-x 2 root root 4096 Jun 6 10:23 abc -rw-r--r-- 1 root root 0 Jun 6 10:23 abc.txt
先看上方藍色的部分,第一位為識別符,去掉第一位,後面每三位分隔,以abc資料夾為例:d | rws | r-x | r-x
所以abc資料夾中表示owner擁有rwx(7) ,group擁有rx(5),other擁有rx(5)。
同樣上方檔案中紅色的部分,依序為擁有者的名稱和所屬群組的名稱,也就是abc資料夾的擁有者為root,所屬群組為root。此時:
a、如果是root用戶來存取這個abc資料夾,相當與owner,擁有7的權限
b、如果一個新的用戶名test用戶群組為root來存取abc資料夾,則相當於group,擁有5的權限
c、如果一個新的使用者名稱test使用者群組為test的來存取abc資料夾,則相當與other,擁有5的權限
二、文件各權限的作用
本來還想邊測試邊說,但是太麻煩了,直接說結果吧。可以自己新建一個用戶,然後修改權限來自己測試下。
1、目錄
a、進入目錄,即cd指令,所需的權限為執行權限(x)
b、檢視目錄內的文件,即ls指令,所需的權限為讀取權限(r)
c、建立刪除目錄內的資料夾/文件,即mkdir/touch命名,需要的權限為寫如權限(w)
順便說下目錄只影響下一級的,隔代不影響,好比一個目錄abc/sub/,如果abc沒有w權限,但sub有w權限,則可以在sub中創建文件,當然abc也需要有x權限,否則都進不去更不用說創建了,但只要能進去(可以透過切換root管理員的方法),就不會再受abc的影響,只會受sub的影響。
一般我們目錄會給5(rx)的權限,也就是讀取和執行權限,只有圖片上傳或快取等目錄需要創建的才會給7(rwx)的權限
#2、檔案
a、檔案打開,可以用cat/vim指令打開,所需權限為讀取權限(r)
b、檔案修改,可以用cat/vim指令開啟並儲存,所需權限為寫入權限(w)
c、檔案執行,可以直接./abc.out等執行,所需要權限為執行權限(x)
#這裡要說明的是php(或shell等)無論是命令列執行還是web端執行,名為執行,實際上是讀取檔到php核心取解析,所以只要有讀取權限(r)就可以。
一般我們檔案會給4(r)權限,也就是讀取權限,只有日誌、快取等需要寫入內容到檔案中的才會給6(rx)權限
之所以上方沒有說755,777、644權限,而只是是說單一的權限,是因為你的網站目錄所屬的權限不能確保與執行時所用的用戶什麼關係,也就是說執行時的用戶可能是owner、可能是group也可能是other
三、php執行時的權限
我們自己在ssh連接linux操作時必須要有個用戶名才能登入操作,同樣php要想處理php相關的文件,也是在某個使用者下操作的,而使用者是在哪裡建立或定義的呢,一般會是在安裝php環境時建立的,例如apache,nginx等環境都會預設建立使用者和使用者群組,而php的讀取時就用此用戶來讀取,可以透過查看設定檔來確認:
#apache在配置文件httpd.conf User www Group www #nginx在配置文件nginx.conf user www www;
或是透過命名查看進程:
#查看apache进程 ps -ef|grep httpd #查看nginx进程 ps -ef|grep nginx #查看php-pfm进行 ps -ef|grep php-pfm
以apache為例會顯示:
root 1663 1 0 09:14 ? 00:00:00 /www/wdlinux/apache/bin/httpd//主进程 www 1697 1663 0 09:14 ? 00:00:05 /www/wdlinux/apache/bin/httpd//子进程 www 1698 1663 0 09:14 ? 00:00:05 /www/wdlinux/apache/bin/httpd
第一行就是顯示的哪個使用者在執行它,主要看非root下的。上方說明是www使用者在執行apache進程來處理php檔。
這裡要注意的是,如果有安裝php-pfm,則應該也需要查看php-pfm執行時的使用者名稱及使用者群組。 (沒有安裝,所以沒實踐過)
預設的可能是nobody或apache等其它的使用者及使用者群組,上方是已修改過的。此時應該在網站目錄中用ls-all來確認下網站檔案是屬於哪個用戶,分幾種情況說明下吧:
a、例如網站所有者是這樣:
drwxr-xr-x 2 www www 4096 Jun 6 10:23 system drwxr-xr-x 2 www www 4096 Jun 6 10:23 tmp -rw-r--r-- 1 www www 0 Jun 6 10:23 index.php ...
網站所有者為www,而php執行者也為www,那說明是具有owner權限,上方system資料夾中755中的55根本不起作用,只要是7xx就會以7(rwx)的權限來執行。
b、如果網站所有者是這樣:
drwxr-xr-x 2 test www 4096 Jun 6 10:23 system drwxr-xr-x 2 test www 4096 Jun 6 10:23 tmp -rw-r--r-- 1 test www 0 Jun 6 10:23 index.php ...
网站所有者为test,所属组为www,而php执行者为www,执行组为www,那说明是说在同一组中,具有group权限,上方system文件夹中755中的7和5不起作用,只要是x5x就会以5(rx)的权限来执行。
c、如果网站所有者是这样:
drwxr-xr-x 2 test test 4096 Jun 6 10:23 system drwxr-xr-x 2 test test 4096 Jun 6 10:23 tmp -rw-r--r-- 1 test test 0 Jun 6 10:23 index.php ...
网站所有者为test,所属组为test,而php执行者为www,执行组为www,那说明是说根本没什么关系,具有other权限,上方system文件夹中755中的75不起作用,只要是xx5就会以5(rx)的权限来执行。
所以不能简单的说修改权限为755,644什么的,还需要确认程序的执行者和网站的所有者才能确定权限。
目前好多集成环境为了省事(嗯,lanmpv3等),将php的执行权限和网站所在目录都设置为www,此时一般创建完目录后为755,创建文件后为644,当php执行时,起作用的目录权限为7(所有目录拥有创建删除权限)和文件权限6(所有文件具有写权限),这种是不是挺不安全的?正常应该是目录为5,文件为4,当有特殊需求时才将权限设为7。如果出现上方说的这种情况,修改的方法一是修改apache/nginx的用户和用户组,二是修改网站文件的所有者和所有组这两个方向来修改,以确保网站的安全。
以上,只是基础的权限说明。
相关推荐:
php以fastCGI的方式运行时文件系统权限问题及解决方法
以上是Linxu下執行時php檔案權限的方法有哪些?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

使用數據庫存儲會話的主要優勢包括持久性、可擴展性和安全性。 1.持久性:即使服務器重啟,會話數據也能保持不變。 2.可擴展性:適用於分佈式系統,確保會話數據在多服務器間同步。 3.安全性:數據庫提供加密存儲,保護敏感信息。

在PHP中實現自定義會話處理可以通過實現SessionHandlerInterface接口來完成。具體步驟包括:1)創建實現SessionHandlerInterface的類,如CustomSessionHandler;2)重寫接口中的方法(如open,close,read,write,destroy,gc)來定義會話數據的生命週期和存儲方式;3)在PHP腳本中註冊自定義會話處理器並啟動會話。這樣可以將數據存儲在MySQL、Redis等介質中,提升性能、安全性和可擴展性。

SessionID是網絡應用程序中用來跟踪用戶會話狀態的機制。 1.它是一個隨機生成的字符串,用於在用戶與服務器之間的多次交互中保持用戶的身份信息。 2.服務器生成並通過cookie或URL參數發送給客戶端,幫助在用戶的多次請求中識別和關聯這些請求。 3.生成通常使用隨機算法保證唯一性和不可預測性。 4.在實際開發中,可以使用內存數據庫如Redis來存儲session數據,提升性能和安全性。

在無狀態環境如API中管理會話可以通過使用JWT或cookies來實現。 1.JWT適合無狀態和可擴展性,但大數據時體積大。 2.Cookies更傳統且易實現,但需謹慎配置以確保安全性。

要保護應用免受與會話相關的XSS攻擊,需採取以下措施:1.設置HttpOnly和Secure標誌保護會話cookie。 2.對所有用戶輸入進行輸出編碼。 3.實施內容安全策略(CSP)限制腳本來源。通過這些策略,可以有效防護會話相關的XSS攻擊,確保用戶數據安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显著提升应用在高并发环境下的效率。

theSession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceisesneededeededeedeedeededto toavoidperformance andunununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函數配置會話名稱。具體步驟如下:1.使用session_name()函數設置會話名稱,例如session_name("my_session")。 2.在設置會話名稱後,調用session_start()啟動會話。配置會話名稱可以避免多應用間的會話數據衝突,並增強安全性,但需注意會話名稱的唯一性、安全性、長度和設置時機。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載
最受歡迎的的開源編輯器

禪工作室 13.0.1
強大的PHP整合開發環境