So führen Sie SUDO-erforderliche Shell-Skripte aus PHP aus
Das Ausführen von Shell-Skripten, die erhöhte Berechtigungen aus PHP heraus erfordern, kann eine Herausforderung sein, da die Die Funktion „shell_exec()“ unterstützt keine Passwortabfragen. Es gibt jedoch Möglichkeiten, diese Einschränkung zu überwinden und die Skriptausführung zu automatisieren.
Lösung: Ändern Sie die Sudoers-Datei
Eine effektive Lösung besteht darin, die Sudoers-Datei (normalerweise unter „ unter /etc/sudoers) und fügen Sie eine Regel hinzu, die die Ausführung des angegebenen Skripts ohne Passwort ermöglicht. Befolgen Sie dazu diese Schritte:
Öffnen Sie die sudoers-Datei mit Root-Rechten mit dem folgenden Befehl:
sudo visudo
Fügen Sie eine Zeile hinzu im folgenden Format:
www-data ALL=NOPASSWD: /path/to/script
wobei www-data der Benutzername des Webservers und /path/to/script der Pfad ist zum Bash-Skript, das erhöhte Rechte erfordert.
Durch diese Änderung erteilen Sie dem Webserver-Benutzer effektiv die Berechtigung zur Ausführung das angegebene Skript, ohne zur Eingabe eines Passworts aufgefordert zu werden.
Sobald Sie diese Schritte ausgeführt haben, können Sie Ihr Bash-Skript von PHP aus mit der Funktion „shell_exec()“ aufrufen üblich. Das Skript wird mit erhöhten Rechten und ohne Passwortabfrage ausgeführt.
Das obige ist der detaillierte Inhalt vonWie kann ich von PHP aus Sudo-erforderliche Shell-Skripte ohne Passwortabfrage ausführen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!