Maison > développement back-end > tutoriel php > Exemple de fonction d'opération de fichier PHP : traversée de répertoire

Exemple de fonction d'opération de fichier PHP : traversée de répertoire

WBOY
Libérer: 2023-06-21 10:32:01
original
824 Les gens l'ont consulté

PHP est un langage de programmation très populaire et largement utilisé pour le développement Web, en particulier le développement côté serveur. L'opération sur les fichiers est une partie essentielle du développement Web. PHP fournit une multitude de fonctions d'opération sur les fichiers. Cet article présentera l'une d'entre elles : la traversée de répertoires.

La traversée de répertoires fait référence à la traversée des répertoires du système de fichiers et à l'obtention des fichiers et sous-répertoires dans les répertoires. Dans le développement Web, la traversée de répertoires est souvent utilisée pour des fonctions telles que la création de plans de site et la gestion des ressources de fichiers, et elle peut également être utilisée pour la détection des vulnérabilités de sites Web et d'autres aspects. Ci-dessous, nous utiliserons des exemples pour apprendre la fonction de traversée de répertoire de PHP. La fonction

  1. opendir()

opendir() est utilisée pour ouvrir un répertoire et renvoyer un handle de ressource. L'argument de cette fonction est le chemin d'accès au répertoire à ouvrir. Si l’ouverture échoue, false sera renvoyé.

Voici un exemple : la fonction

$dir = '/var/www/html';
if ($handle = opendir($dir)) {
    echo "成功打开目录 $dir
";
    closedir($handle);
}
else {
    echo "无法打开目录 $dir
";
}
Copier après la connexion
  1. readdir()

readdir() est utilisée pour lire les fichiers et sous-répertoires dans un répertoire. Le paramètre de cette fonction est le handle de ressource renvoyé par la fonction opendir(). Si un fichier ou un sous-répertoire est lu avec succès, son nom est renvoyé. Si la fin de la lecture est atteinte, false est renvoyé.

Ce qui suit est un exemple : la fonction

$dir = '/var/www/html';
if ($handle = opendir($dir)) {
    echo "成功打开目录 $dir
";
    while (false !== ($file = readdir($handle))) {
        echo "$file
";
    }
    closedir($handle);
}
else {
    echo "无法打开目录 $dir
";
}
Copier après la connexion
  1. is_dir()

is_dir() est utilisée pour déterminer si un fichier est un répertoire. Le paramètre de cette fonction est le chemin du fichier à juger. Renvoie vrai s'il s'agit d'un répertoire, faux sinon.

Voici un exemple :

$file = '/var/www/html/index.php';
if (is_dir($file)) {
    echo "$file 是一个目录
";
}
else {
    echo "$file 不是一个目录
";
}
Copier après la connexion
  1. RecursiveDirectoryIterator

La classe RecursiveDirectoryIterator est utilisée pour parcourir de manière récursive un répertoire et ses sous-répertoires. Cette classe prend deux paramètres : le premier est le chemin du répertoire à parcourir et le second est un indicateur facultatif qui spécifie le mode de parcours. Si le deuxième paramètre n'est pas défini, tous les sous-répertoires et fichiers seront parcourus par défaut, y compris les fichiers cachés.

Voici un exemple :

$dir = '/var/www/html';
$iterator = new RecursiveDirectoryIterator($dir, RecursiveDirectoryIterator::SKIP_DOTS);
foreach (new RecursiveIteratorIterator($iterator) as $file) {
    echo $file . "
";
}
Copier après la connexion

Le code ci-dessus traversera tous les fichiers du répertoire spécifié et ses sous-répertoires, mais ne traversera pas les répertoires "." et ".." Dans le résultat du parcours, la valeur de chaque élément est un objet SplFileInfo, et le nom du fichier, la taille du fichier, l'heure de modification et d'autres informations peuvent être obtenues via les méthodes de cet objet. De plus, la classe SplFileInfo fournit également des fonctions telles que vider le cache, ce qui peut rendre le programme plus efficace.

Résumé

La traversée de répertoires est une opération couramment utilisée dans le développement Web. PHP fournit une multitude de fonctions et de classes de traversée de répertoires. Lorsque vous parcourez le répertoire, vous devez faire attention aux autorisations de fichiers, au format du chemin et à d'autres problèmes pour garantir que le programme fonctionne correctement. Dans le même temps, afin d'empêcher des attaquants malveillants d'utiliser les vulnérabilités de traversée de répertoires pour attaquer le site, nous devons également prendre certaines mesures de sécurité, telles que la restriction des chemins de traversée, la désactivation des fichiers malveillants, etc.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal