Heim  >  Artikel  >  Backend-Entwicklung  >  Lösung für das Problem von PHP mkdir() ohne Schreibberechtigung

Lösung für das Problem von PHP mkdir() ohne Schreibberechtigung

高洛峰
高洛峰Original
2016-12-21 15:18:381403Durchsuche

Bei der Verwendung von mkdir zum Erstellen eines Ordners habe ich festgestellt, dass diese Funktion zwei Parameter hat. Der zweite Parameter gibt Berechtigungen für den neu erstellten Ordner an.

Aber wenn Sie mkdir('file address', 0777); direkt verwenden, werden Sie feststellen, dass die Berechtigungen des neuen Ordners nicht 777, sondern normalerweise 022 sind.

Denn wenn mkdir Berechtigungen für einen Ordner festlegt, führt es eine bitweise UND-Verknüpfung mit dem umask-Wert (Standardberechtigungsattribut des Benutzers) des aktuell beim Betriebssystem angemeldeten Benutzers durch, und der resultierende Wert ist der endgültige Berechtigungswert .

Was ist umask?

Wie erhalten wir die Standardberechtigungen für die von uns erstellten Dateien? Wie ändere ich diese Standardberechtigung?

Wenn wir uns beim System anmelden und eine Datei erstellen, gibt es immer eine Standardberechtigung. Woher kommt diese Berechtigung? Das ist es, was umask tut.

umask legt die Standardberechtigungen für von Benutzern erstellte Dateien fest. Es hat den gegenteiligen Effekt wie chmod umask den Berechtigungscode festlegt, während chmod den Dateiberechtigungscode festlegt. Im Allgemeinen wird der umask-Wert in /etc/profile, $HOME/.bash_profile oder $HOME/.profile festgelegt.

Wie berechnet man den Umask-Wert? Mit dem Befehl

umask können Sie den Standardmodus beim Erstellen von Dateien festlegen. Für jeden Benutzertyp (Dateibesitzer, Benutzer in derselben Gruppe, andere Benutzer) gibt es eine entsprechende Zahl im umask-Wert. Für Dateien beträgt der Maximalwert dieser Zahl 6. Das System erlaubt es Ihnen nicht, einer Textdatei beim Erstellen eine Ausführungsberechtigung zu erteilen. Sie müssen den Befehl chmod verwenden, um diese Berechtigung nach der Erstellung zu erhöhen. Verzeichnisse ermöglichen das Festlegen von Ausführungsberechtigungen, daher kann die maximale Anzahl in umask für Verzeichnisse bis zu 7 betragen.

Die allgemeine Form dieses Befehls ist: umask nnn, wobei nnn zwischen 000 und 777 liegen kann.

Wir müssen uns nur daran erinnern, dass umask das entsprechende Bit aus den Berechtigungen „wegnimmt“.

Zum Beispiel: Wenn der umask-Wert 022 ist, ist die Standardverzeichnisberechtigung 755 und die Standarddateiberechtigung 644.
Wenn also die Benutzer-umask 022 ist (normalerweise ist dies die Standardeinstellung), ist 000 010 010 gleich 777, das von mkdir angegeben wird, also 111 111 111. Nach dem „AND“ wird die tatsächliche Berechtigung erhalten ist: 022.

Wenn Sie die Berechtigungen des neuen Ordners maximieren möchten, gibt es zwei Möglichkeiten, dies zu erreichen: (natürlich unter der Bedingung, dass der aktuelle Benutzer die höchsten Berechtigungen erteilen kann)

1 . Ändern Sie den Benutzer umask, php Die umask-Funktion wird bereitgestellt:

$oldumask=umask(0); 
mkdir('test',0777); 
umask($oldumask);

Diese Methode scheint ein für alle Mal zu funktionieren. Geben Sie den umask-Wert in der Eröffnungsdatei des Skripts an und verwenden Sie dann direkt mkdir Kontrollberechtigungen Es ist zu beachten, dass auf einem Multithread-Server bei Verwendung der umask-Funktion mehrere Threads eine umask teilen, sodass es zu Verwirrung kommen kann.

2. Verwenden Sie die Funktion chmod, die auch die am häufigsten verwendete Methode ist:

mkdir('文件地址', 0777); 
chmod('文件地址', 0777);

Abschließend ist zu beachten, dass der Berechtigungswert am besten in Oktal ausgedrückt wird, was mit beginnt „0“ und muss sein. Setzen Sie keine Anführungszeichen.

Weitere verwandte Artikel zur Lösung des Problems von PHP mkdir() ohne Schreibberechtigung finden Sie auf der chinesischen PHP-Website!


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn