Maison  >  Article  >  développement back-end  >  Aide-mémoire de configuration de sécurité PHP maintenu par OWASP

Aide-mémoire de configuration de sécurité PHP maintenu par OWASP

藏色散人
藏色散人avant
2019-12-03 14:02:472052parcourir

Aide-mémoire de configuration de sécurité PHP maintenu par OWASP

Introduction

Le but de cette page est d'aider ceux qui configurent PHP et les serveurs Web qui l'exécutent à garantir sa sécurité.

Vous trouverez ci-dessous les informations de configuration correctes pour le fichier php.ini.

php.ini

Certains des paramètres suivants doivent être adaptés à votre système, notamment session.save_path, session.cookie_path (par exemple : /var/www /monsite) et session.cookie_domain (par exemple : ExempleSite.com).

Vous devez également exécuter PHP 7.2 ou supérieur. Si vous utilisez PHP 7.0 et PHP 7.1, vous utiliserez des valeurs légèrement différentes à quelques endroits ci-dessous (voir les commentaires en ligne).

Enfin, consultez la documentation PHP pour une référence sur chaque valeur dans le fichier de configuration php.ini.

Vous pouvez trouver une copie de la configuration suivante dans un fichier php.ini prêt à l'emploi ici .

Gestion des erreurs PHP

expose_php              = Off
error_reporting         = E_ALL
display_errors          = Off
display_startup_errors  = Off
log_errors              = On
error_log               = /valid_path/PHP-logs/php_error.log
ignore_repeated_errors  = Off

Veuillez noter : vous devez définir display_errors sur Off dans l'environnement de production, et il est préférable de développer une bonne habitude de vérifier ces journaux fréquemment.

Paramètres communs PHP

doc_root                = /path/DocumentRoot/PHP-scripts/
open_basedir            = /path/DocumentRoot/PHP-scripts/
include_path            = /path/PHP-pear/
extension_dir           = /path/PHP-extensions/
mime_magic.magicfile    = /path/PHP-magic.mime
allow_url_fopen         = Off
allow_url_include       = Off
variables_order         = "GPCS"
allow_webdav_methods    = Off
session.gc_maxlifetime  = 600

allow_url_* est sujet aux vulnérabilités complètes LFI et RFI.

Traitement des fichiers de téléchargement PHP

file_uploads            = On
upload_tmp_dir          = /path/PHP-uploads/
upload_max_filesize     = 2M
max_file_uploads        = 2

Si votre application n'utilise pas la fonction de téléchargement de fichiers, ou si le seul moyen pour les utilisateurs de saisir des téléchargements est via un formulaire qui ne le fait pas contenir des pièces jointes aux documents Pour soumettre, file_uploads doit être défini sur Off.

Traitement des exécutables PHP

enable_dl               = Off
disable_functions       = system, exec, shell_exec, passthru, phpinfo, show_source, highlight_file, popen, proc_open, fopen_with_path, dbmopen, dbase_open, putenv, move_uploaded_file, chdir, mkdir, rmdir, chmod, rename, filepro, filepro_rowcount, filepro_retrieve, posix_mkfifo
# 请查看:http://ir.php.net/features.safe-mode
disable_classes         =

Les méthodes et classes ci-dessus sont dangereuses en PHP. Vous devez désactiver les méthodes et classes qui ne sont pas utilisées.

Traitement de la session PHP

Il y a certaines valeurs auxquelles il faut prêter attention dans les paramètres de session. C'est un bon exercice pour changer le nom de la session. à un nouveau.

 session.save_path                = /path/PHP-session/
 session.name                     = myPHPSESSID
 session.auto_start               = Off
 session.use_trans_sid            = 0
 session.cookie_domain            = full.qualified.domain.name
 #session.cookie_path             = /application/path/
 session.use_strict_mode          = 1
 session.use_cookies              = 1
 session.use_only_cookies         = 1
 session.cookie_lifetime          = 14400 # 4小时 
 session.cookie_secure            = 1
 session.cookie_httponly          = 1
 session.cookie_samesite          = Strict
 session.cache_expire             = 30 
 session.sid_length               = 256
 session.sid_bits_per_character   = 6 # PHP 7.2+
 session.hash_function            = 1 # PHP 7.0-7.1
 session.hash_bits_per_character  = 6 # PHP 7.0-7.1

Plus de contrôles pour les risques de sécurité

session.referer_check   = /application/path
memory_limit            = 50M
post_max_size           = 20M
max_execution_time      = 60
report_memleaks         = On
track_errors            = Off
html_errors             = Off

Adresse originale en anglais :

https://github.com/OWASP/ CheatSheetSeries/blob/master/cheatsheets /PHP_Configuration_Cheat_Sheet.md

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer