Maison >développement back-end >Problème PHP >Comment désactiver le mode safe_mode de php ?
Méthode de fermeture : dans le fichier de configuration php.ini, recherchez "safe_mode =" et définissez-le sur "safe_mode = Off" ; puis redémarrez php, ou redémarrez tout l'environnement pour désactiver php safe_mode (mode sans échec). ) .
Comment désactiver le mode safe_mode de php
Certains environnements doivent activer le mode sans échec (safe_mode ), ce qui empêchera l'utilisation de nombreuses fonctions PHP intégrées du programme et paralysera le système. Il est recommandé de le fermer.
Définissez safe_mode = Off
dans le fichier php.ini, puis redémarrez php, ou redémarrez tout l'environnement. [Tutoriels associés recommandés : "Tutoriel PHP"]
Sur la photo :
Informations détaillées
Qu'est-ce que le mode sans échec PHP : safe_mode
En termes simples, le mode sans échec PHP consiste à exécuter php en mode sans échec.
Le mode sans échec de php fournit un environnement partagé sécurisé de base sur un serveur Web ouvert php où existent plusieurs comptes d'utilisateurs. Lorsque PHP s'exécute en mode sans échec sur un serveur Web, certaines fonctions seront complètement désactivées et certaines fonctions disponibles seront limitées.
En mode sans échec, certaines fonctions qui tentent d'accéder au système de fichiers seront restreintes. En exécutant l'ID utilisateur du serveur Web, si vous souhaitez exploiter un certain fichier, vous devez disposer de droits d'accès en lecture ou en écriture sur le fichier. PHP n'a aucun problème à implémenter cette fonction de restriction.
Lorsque le mode sans échec est activé, lorsque vous essayez de lire ou d'écrire un fichier local, PHP vérifiera si l'utilisateur qui accède actuellement est le propriétaire du fichier cible. Si vous n'êtes pas propriétaire, l'opération sera désactivée.
(Autorisations d'écriture : sous les autorisations d'accès aux fichiers de niveau inférieur, il peut être autorisé à lire ou à écrire des fichiers dans le système d'exploitation du système. Ceci est obtenu grâce au mode sans échec de PHP pour vous empêcher d'utiliser les fichiers d'un autre utilisateur. opération . Bien entendu, un serveur Web peut accéder à un fichier arbitraire avec des autorisations d'écriture globales)
Lorsque le mode sans échec est activé, la fonctionnalité de la liste de fonctions suivante sera restreinte :
.chdir, move_uploaded_file, chgrp, parse_ini_file, chown, rmdir, copy, rename, fopen, require, highlight_file, show_source, include, symlink, link, touch, mkdir, unlink
De même, certains les fonctions des extensions PHP seront également affectées. (Chargement des modules : La fonction dl sera désactivée en mode sans échec. Si vous souhaitez charger une extension, vous ne pouvez modifier les options de l'extension que dans php.ini et la charger au démarrage de PHP)
Ouvert en PHP sécurisé mode Lorsque vous devez exécuter un programme système, il doit s'agir du programme dans le répertoire spécifié dans l'option safe_mode_exec_dir, sinon l'exécution échouera. Même si l'exécution est autorisée, elle sera automatiquement transmise à la fonction escapeshellcmd pour le filtrage.
La liste de fonctions suivante pour l'exécution des commandes sera affectée :
exec,shell_exec,passthru,system,popen
De plus, l'opérateur de marquage arrière (`) sera également être affecté par la fermeture.
Lors de l'exécution en mode sans échec, même si aucune erreur ne sera provoquée, la fonction putenv sera invalide. De même, les autres fonctions set_time_limit et set_include_path qui tentent de modifier les variables d'environnement PHP seront également ignorées.
Apprentissage recommandé : Programmation PHP du débutant au compétent
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!