ホームページ >バックエンド開発 >PHPチュートリアル >PHP mkdir() に書き込み権限がない場合の解決策_PHP チュートリアル
mkdir を使用してフォルダーを作成する場合、この関数には 2 つのパラメーターがあることがわかりました。2 番目のパラメーターは、新しく作成されたフォルダーのアクセス許可を指定します。
ただし、 mkdir('file address', 0777); を直接使用すると、新しいフォルダーのアクセス許可が 777 ではなく、通常は 022 であることがわかります。
mkdir がフォルダーのアクセス許可を設定するとき、現在オペレーティング システムにログインしているユーザーの umask (ユーザーのデフォルトのアクセス許可属性) 値とのビット "AND" が実行され、その結果の値が最終的なアクセス許可の値になるためです。
umaskそれは何ですか?
ファイルを作成するためのデフォルトの権限はどこで取得できますか?このデフォルトの権限を変更するにはどうすればよいですか?
システムにログインしてファイルを作成すると、常にデフォルトの権限が与えられます。では、この権限はどこから来るのでしょうか?これが umask の機能です。
umask は、ユーザーが作成したファイルのデフォルトのアクセス許可を設定します。これは、chmod がファイルのアクセス許可コードを設定するのに対し、umask は「補完コード」を設定します。通常、umask 値は /etc/profile、$HOME/.bash_profile、または $HOME/.profile に設定されます。
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 に等しい場合、「AND」の後、取得される実際の権限は 022 になります。 。
新しいフォルダーの権限を最大化したい場合、それを実現する方法が 2 つあります: (もちろん、現在のユーザーが最高の権限を付与できるという条件の下で)
1. ユーザー umask を変更します。PHP は umask 関数を提供します:
2. chmod 関数を使用します。これも最も一般的に使用される方法です。
コードをコピーします
www.bkjia.com