Maison >développement back-end >tutoriel php >Protection de sécurité PHP : renforcer le contrôle des autorisations des répertoires
Dans le développement Web, les répertoires jouent un rôle important dans la fourniture des ressources requises par les applications Web. Cependant, si les autorisations d'accès au répertoire de fichiers sont incorrectes, cela peut facilement entraîner des problèmes de sécurité Web. Par exemple, un tiers non autorisé peut télécharger des fichiers malveillants sur votre serveur, provoquant ainsi une attaque du serveur. Par conséquent, pendant le processus de développement d’applications Web, le contrôle des autorisations des répertoires doit être renforcé pour empêcher les accès illégaux et les téléchargements de fichiers malveillants.
Afin de renforcer le contrôle des autorisations de répertoire, nous pouvons prendre les mesures suivantes :
Dans les systèmes Linux, les autorisations de répertoire peuvent être contrôlées via la commande chmod. La commande spécifique est la suivante :
chmod 700 /var/www/html/uploads/
La signification de la commande ci-dessus est que seul le propriétaire du répertoire (généralement le processus du serveur Web) a des autorisations d'accès, d'écriture et d'exécution sur le répertoire, et les autres n'ont pas d'autorisations d'accès.
Certains répertoires sont utilisés pour stocker des fichiers de script, tels que les fichiers de script PHP, qui peuvent être exécutés par le processus du serveur Web. Si le processus du serveur Web est compromis, ce répertoire peut être utilisé pour stocker et exécuter des scripts malveillants. Pour éviter que cela ne se produise, nous pouvons désactiver l'exécution des fichiers de script dans le répertoire via le fichier de configuration Apache. La méthode spécifique est la suivante :
Dans le fichier de configuration Apache, recherchez le code suivant :
<Directory /var/www/html/> Options Indexes FollowSymLinks AllowOverride None Require all granted </Directory>
Modifiez-le en :
<Directory /var/www/html/> Options Indexes FollowSymLinks AllowOverride None Require all granted AddHandler txt .txt AddHandler html .html AddHandler htm .htm AddHandler php .php .inc </Directory> <FilesMatch ".(php|inc)$"> Order Deny,Allow Deny from all </FilesMatch>
Dans le fichier de configuration ci-dessus, nous avons ajouté quelques types MIME afin que le serveur Apache puisse servir du HTML , TXT et servir des fichiers PHP. Ensuite, en faisant correspondre les noms de fichiers PHP et INC dans la balise b5b7f795fbd764be2f6705fd2f78034b, nous désactivons l'exécution des fichiers PHP et INC dans tous les répertoires.
Dans certaines applications Web, les utilisateurs peuvent télécharger des fichiers tels que des images et des documents. Cependant, ces fichiers téléchargés peuvent contenir du code malveillant et les attaquants peuvent exploiter les vulnérabilités de téléchargement des fichiers utiles pour transmettre des fichiers malveillants au serveur. Pour prévenir les attaques, nous pouvons renforcer la sécurité des téléchargements de fichiers en :
En général, lors du développement d'applications Web, le renforcement du contrôle des autorisations d'annuaire est un moyen important de se défendre contre les attaques Web. En contrôlant raisonnablement et strictement les autorisations d'accès aux répertoires de fichiers, les comportements malveillants peuvent être efficacement réduits. Le contrôle des autorisations d'annuaire est une condition préalable nécessaire à la sécurité Web, et les programmeurs et les gestionnaires doivent y prêter attention.
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!