Heim > Artikel > Backend-Entwicklung > Das Problem besteht darin, dass die PHP-Funktion mkdir() keine Schreibberechtigung hat
Bei der Verwendung von mkdir zum Erstellen eines Ordners habe ich festgestellt, dass diese -Funktion zwei Parameter hat, der zweite Parameter ist für den neu erstellten Dateiordner angegebene Berechtigungen. 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, 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 (Dateieigentümer, 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 die Benutzer-umask, php. Die umask-Funktion wird bereitgestellt:
Der Code lautet wie folgt:
$oldumask=umask(0); mkdir('test',0777); umask($oldumask);
Diese Methode scheint einmal zu funktionieren Geben Sie den umask-Wert in der Eröffnungsdatei des Skripts an. Sie können die Berechtigungen dann direkt mit mkdir steuern. Beachten Sie, dass bei Verwendung der umask-Funktion auf einem Multithread-Server mehrere Threads eine umask teilen es kann Verwirrung stiften.
2. Verwenden Sie die chmod-Funktion, die auch die am häufigsten verwendete Methode ist:
Code Der Code lautet wie folgt:
mkdir('文件地址', 0777); chmod('文件地址', 0777);
Schließlich benötigen Sie Beachten Sie, dass der Berechtigungswert am besten oktal ausgedrückt wird, d. h. beginnend mit „0“, und achten Sie darauf, keine Anführungszeichen hinzuzufügen.
Das obige ist der detaillierte Inhalt vonDas Problem besteht darin, dass die PHP-Funktion mkdir() keine Schreibberechtigung hat. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!