recherche
Maisondéveloppement back-endtutoriel phpComment prévenir les vulnérabilités de téléchargement de fichiers à l'aide de PHP

Comment prévenir les vulnérabilités de téléchargement de fichiers à l'aide de PHP

Jun 24, 2023 am 08:25 AM
安全防护php 编程文件上传漏洞

Avec la popularité d'Internet et l'augmentation des types de sites Web, la fonction de téléchargement de fichiers est devenue de plus en plus courante, mais la fonction de téléchargement de fichiers est également devenue l'une des cibles clés des attaquants. Les attaquants peuvent prendre le contrôle du site Web et voler les informations des utilisateurs en téléchargeant des fichiers malveillants sur le site Web et en adoptant une série de comportements malveillants. Par conséquent, la manière de prévenir les vulnérabilités de téléchargement de fichiers est devenue un problème important en matière de sécurité Web. Cet article explique comment utiliser PHP pour empêcher les vulnérabilités de téléchargement de fichiers.

  1. Vérifiez les types et extensions de fichiers

Les attaquants se déguisent souvent en fichiers non menaçants tels que des images et obtiennent des autorisations système en téléchargeant des fichiers malveillants, il est donc très nécessaire de vérifier le type et l'extension des fichiers téléchargés.

Tout d'abord, vous pouvez utiliser $_FILES'file' pour obtenir le type de fichier téléchargé, juger du type de fichier et autoriser uniquement le téléchargement de types de fichiers spécifiés, tels que les formats d'image (png, jpg, etc.).

Deuxièmement, vous pouvez utiliser la fonction pathinfo() pour obtenir l'extension du fichier téléchargé. L'extension est également jugée et seule l'extension spécifiée peut être téléchargée. Cependant, il convient de noter que les extensions de certains fichiers peuvent être falsifiées, il faut donc combiner d'autres moyens pour renforcer la protection.

  1. Vérifier la taille du fichier

Un attaquant peut consommer les ressources du serveur en téléchargeant des fichiers volumineux, provoquant une charge excessive du serveur. Par conséquent, il est également nécessaire de limiter la taille des fichiers téléchargés.

Vous pouvez définir une taille de fichier maximale et autoriser uniquement le téléchargement de fichiers plus petits que cette taille. D’une manière générale, une taille d’environ 2 Mo est plus appropriée.

  1. Nom de fichier aléatoire

Un attaquant peut remplacer le fichier d'origine en téléchargeant un fichier du même nom, provoquant la perte ou l'attaque du fichier d'origine. Par conséquent, le nom du fichier téléchargé peut être randomisé pour générer un nom de fichier unique afin d'éviter que le fichier ne soit remplacé ou que les visiteurs n'obtiennent le chemin du fichier.

Vous pouvez utiliser la fonction uniqid() combinée avec l'horodatage pour générer un nom de fichier aléatoire unique et ajouter l'extension du nom de fichier d'origine à la fin. Par exemple :

$filename = uniqid().time() '.' pathinfo($_FILES'file', PATHINFO_EXTENSION);

  1. Déplacez le fichier vers le répertoire spécifié

Une fois le téléchargement réussi, le fichier téléchargé doit être déplacé vers le répertoire spécifié. Certaines vérifications de sécurité doivent être effectuées sur les fichiers téléchargés avant de les déplacer vers le répertoire.

Par exemple, vous devez déterminer les autorisations du répertoire de téléchargement et vous assurer que le répertoire de téléchargement ne se trouve pas sous le répertoire racine Web. Il est préférable de définir le répertoire de téléchargement en lecture seule et de garantir que les noms de fichiers ne contiennent pas d'informations sensibles.

  1. Empêcher l'écrasement des fichiers

Pendant le processus de téléchargement de fichiers, des fichiers portant le même nom peuvent être téléchargés. Si le fichier téléchargé ultérieurement porte le même nom que le fichier d'origine, le fichier d'origine peut être écrasé. Par conséquent, les fichiers téléchargés peuvent être renommés pour garantir qu'ils ne seront pas écrasés.

Vous pouvez ajouter un fichier de compteur dans le répertoire de téléchargement pour enregistrer le nombre de fichiers téléchargés. Le compteur sera incrémenté de 1 à chaque téléchargement et la valeur du compteur sera utilisée dans le nom du fichier.

  1. Empêcher l'exécution de code malveillant

Si le fichier téléchargé est remplacé par du code PHP malveillant, cela entraînera une grande menace pour la sécurité. Par conséquent, vous devez vous assurer que le fichier téléchargé ne sera pas exécuté en tant que fichier exécutable.

Vous pouvez modifier le fichier de configuration Apache et ajouter le code suivant :


ForceType application/octet-stream
Header set Content-Disposition attachment

This will Tous les fichiers se terminant par .php sont définis comme des fichiers binaires et sont définis comme pièces jointes lors du téléchargement.

De plus, les fichiers pouvant être téléchargés ne peuvent être que des images, du texte et d'autres fichiers au format, et les fichiers dangereux tels que les fichiers exécutables et les fichiers de script ne peuvent pas être téléchargés.

  1. Journalisation et surveillance

Enfin, la journalisation et la surveillance sont nécessaires pour faciliter la découverte des problèmes et leur traitement en temps opportun. Vous pouvez utiliser la fonction error_log() intégrée de PHP pour enregistrer les informations d'erreur dans un fichier journal, ou utiliser des outils tiers pour la surveillance et l'alarme.

En général, la prévention des vulnérabilités lors du téléchargement de fichiers nécessite l'utilisation complète d'une variété de méthodes et de moyens pour améliorer la sécurité autant que possible. Les méthodes données ci-dessus peuvent aider les développeurs PHP à éviter les problèmes de vulnérabilité courants, mais ils doivent également effectuer les ajustements et optimisations correspondants en fonction de situations spécifiques.

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
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
PHP et Python: différents paradigmes expliquésPHP et Python: différents paradigmes expliquésApr 18, 2025 am 12:26 AM

PHP est principalement la programmation procédurale, mais prend également en charge la programmation orientée objet (POO); Python prend en charge une variété de paradigmes, y compris la POO, la programmation fonctionnelle et procédurale. PHP convient au développement Web, et Python convient à une variété d'applications telles que l'analyse des données et l'apprentissage automatique.

PHP et Python: une plongée profonde dans leur histoirePHP et Python: une plongée profonde dans leur histoireApr 18, 2025 am 12:25 AM

PHP est originaire en 1994 et a été développé par Rasmuslerdorf. Il a été utilisé à l'origine pour suivre les visiteurs du site Web et a progressivement évolué en un langage de script côté serveur et a été largement utilisé dans le développement Web. Python a été développé par Guidovan Rossum à la fin des années 1980 et a été publié pour la première fois en 1991. Il met l'accent sur la lisibilité et la simplicité du code, et convient à l'informatique scientifique, à l'analyse des données et à d'autres domaines.

Choisir entre PHP et Python: un guideChoisir entre PHP et Python: un guideApr 18, 2025 am 12:24 AM

PHP convient au développement Web et au prototypage rapide, et Python convient à la science des données et à l'apprentissage automatique. 1.Php est utilisé pour le développement Web dynamique, avec une syntaxe simple et adapté pour un développement rapide. 2. Python a une syntaxe concise, convient à plusieurs champs et a un écosystème de bibliothèque solide.

PHP et frameworks: moderniser la languePHP et frameworks: moderniser la langueApr 18, 2025 am 12:14 AM

PHP reste important dans le processus de modernisation car il prend en charge un grand nombre de sites Web et d'applications et d'adapter les besoins de développement via des cadres. 1.Php7 améliore les performances et introduit de nouvelles fonctionnalités. 2. Des cadres modernes tels que Laravel, Symfony et Codeigniter simplifient le développement et améliorent la qualité du code. 3. L'optimisation des performances et les meilleures pratiques améliorent encore l'efficacité de l'application.

Impact de PHP: développement Web et au-delàImpact de PHP: développement Web et au-delàApr 18, 2025 am 12:10 AM

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

Comment fonctionne la résistance au type PHP, y compris les types scalaires, les types de retour, les types d'union et les types nullables?Comment fonctionne la résistance au type PHP, y compris les types scalaires, les types de retour, les types d'union et les types nullables?Apr 17, 2025 am 12:25 AM

Le type PHP invite à améliorer la qualité et la lisibilité du code. 1) Conseils de type scalaire: Depuis PHP7.0, les types de données de base sont autorisés à être spécifiés dans les paramètres de fonction, tels que INT, Float, etc. 2) Invite de type de retour: Assurez la cohérence du type de valeur de retour de fonction. 3) Invite de type d'union: Depuis PHP8.0, plusieurs types peuvent être spécifiés dans les paramètres de fonction ou les valeurs de retour. 4) Invite de type nullable: permet d'inclure des valeurs nulles et de gérer les fonctions qui peuvent renvoyer les valeurs nulles.

Comment PHP gère le clonage des objets (mot-clé de clone) et la méthode de magie __clone?Comment PHP gère le clonage des objets (mot-clé de clone) et la méthode de magie __clone?Apr 17, 2025 am 12:24 AM

Dans PHP, utilisez le mot-clé Clone pour créer une copie de l'objet et personnalisez le comportement de clonage via la méthode de magie du clone \ _ \ _. 1. Utilisez le mot-clé Clone pour faire une copie peu profonde, en clonant les propriétés de l'objet mais pas aux propriétés de l'objet. 2. La méthode du clone \ _ \ _ peut copier profondément les objets imbriqués pour éviter les problèmes de copie superficiels. 3. Faites attention pour éviter les références circulaires et les problèmes de performance dans le clonage et optimiser les opérations de clonage pour améliorer l'efficacité.

PHP vs Python: cas d'utilisation et applicationsPHP vs Python: cas d'utilisation et applicationsApr 17, 2025 am 12:23 AM

PHP convient aux systèmes de développement Web et de gestion de contenu, et Python convient aux scripts de science des données, d'apprentissage automatique et d'automatisation. 1.Php fonctionne bien dans la création de sites Web et d'applications rapides et évolutifs et est couramment utilisé dans CMS tel que WordPress. 2. Python a permis de manière remarquable dans les domaines de la science des données et de l'apprentissage automatique, avec des bibliothèques riches telles que Numpy et Tensorflow.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

SublimeText3 version anglaise

SublimeText3 version anglaise

Recommandé : version Win, prend en charge les invites de code !

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel