使用mkdir創建文件夾時,發現這個函數有兩個參數,第二個參數是為新創建的文件夾指定權限。
但是如果直接用mkdir('文件地址', 0777);時 發現新文件夾的權限並不是777,一般情況下會是022。
因為mkdir在給文件夾制定權限時,會跟當前登錄操作系統用戶的umask(用戶缺省權限屬 性)值進行位“與”,得到的值才是最終權限值。
umask 是什麼?
我們創建文件的默認權限是怎麼來的?如何改變這個默認權限呢?
當我們登錄系統之後創建一個文件總是有一個默認權限的,那麼這個權限是怎麼來的呢?這就是 umask 干的事情。
umask 設置了用戶創建文件的默認權限,它與 chmod 的效果剛好相反,umask 設置的是權限“補碼”,而 chmod 設置的是文件權限碼。一般在 /etc/profile、$HOME/.bash_profile 或 $HOME/.profile 中設置 umask 值。
如何計算 umask 值?
umask 命令允許你設定文件創建時的缺省模式,對應每一類用戶(文件屬主、同組用戶、其他用戶)存在一個相應的 umask 值中的數字。對於文件來說,這一數字的最大值分別是 6。系統不允許你在創建一個文本文件時就賦予它執行權限,必須在創建後用 chmod 命令增加這一權限。目錄則允許設置執行權限,這樣針對目錄來說,umask 中各個數字最大可以到 7。
該命令的一般形式為:umask nnn,其中 nnn 可為 000 - 777。
我們只要記住 umask 是從權限中“拿走”相應的位即可。
如:umask 值為 022,則默認目錄權限為 755,默認文件權限為 644。
所以,如果用戶umask是022(一般默認是這個),即:000 010 010 在於mkdir指定的777 ,即:111 111 111 位“與”後,得到的真實權限為:022。
如果想讓新建文件夾權限最大,有兩種方法可以實現:(當然,是在當前用戶能賦予最高權限的條件下)
1、修改用戶umask,php提供有umask函數:
復制代碼 代碼如下:
$oldumask=umask(0);
mkdir('test',0777);
umask($oldumask);
這種方法看起來一勞永逸,在腳本開頭文件裡指定下umask值,後面直接用mkdir就可以控制權限,需要注意的是:在多線程服務器上使用umask函數時,多個線程會公用一個umask,所以可能會造成混亂。
2、使用chmod函數,這也是最常用的方法:
復制代碼 代碼如下:
mkdir('文件地址', 0777);
chmod('文件地址', 0777);
最後,需要注意一點,權限值最好使用八進制表示,即“0”開頭,而且一定不要加引號。