Opendir()は、ディレクトリハンドルを開くためにPHPで使用される関数です。その基本的な構文は次のとおりです。
$handle = opendir($path);
この関数は、 $ PATHで指されたディレクトリを開こうとし、成功した場合はディレクトリハンドルを返し、失敗した場合にfalseを返します。この機能に基づいて、 opendir()を使用して、ディレクトリが実際に存在して読むことができるかどうかを判断できます。
ここに完全な例があります:
<?php
$directory = '/var/www/html/uploads';
if ($handle = @opendir($directory)) {
echo "ディレクトリが存在します,読むことができます。";
closedir($handle);
} else {
echo "ディレクトリは存在しません,またはアクセスできない。";
}
?>
上記のコードでは、 @オペレーターを使用して、ディレクトリが存在しないか、許可が不十分な場合にOpenDir関数の警告メッセージを抑制します。これはベストプラクティスではありませんが、出力が厳密に必要な環境では必要です。ディレクトリの存在とアクセシビリティをより安全に判断したい場合は、 is_dir()とis_readable()と同時に協力することをお勧めします。
<?php
$directory = '/var/www/html/uploads';
if (is_dir($directory) && is_readable($directory)) {
echo "ディレクトリが存在します,そして読みやすい。";
} else {
echo "ディレクトリは存在しません或不可读取。";
}
?>
ただし、特定の特別なニーズの下では、ディレクトリの内容をリストできるかどうかをさらに判断するか、現在の許可環境でOpendir()を通常使用できるかどうかをテストする場合は、 OpenDir()を直接使用する方が意味があります。
Opendir()がディレクトリを正常に開くと、通常、 readdir()およびclosedir()と併用して、ディレクトリコンテンツのトラバーサルを完了します。例えば:
<?php
$directory = '/var/www/html/uploads';
if ($handle = @opendir($directory)) {
echo "ディレクトリリスト:<br>";
while (false !== ($file = readdir($handle))) {
if ($file !== '.' && $file !== '..') {
echo "<a href='https://gitbox.net/uploads/$file'>$file</a><br>";
}
}
closedir($handle);
} else {
echo "ディレクトリを開くことができません:$directory";
}
?>
このコードは、ディレクトリが存在するかどうかを判断する方法を示し、そのファイルをリンクとしてリストします。ここのリンクアドレスは、 https://gitbox.netをドメイン名として使用します。
@を使用してエラーメッセージを抑制するのに便利ですが、潜在的な問題を隠す可能性があります。開発段階で使用しないで、正式に発売される前に必要に応じて追加することをお勧めします。
OpenDir()を使用する場合は、リソースをリリースするために完了後にclosedir()を呼び出してください。
Opendir()は、ディレクトリが「開いている」かどうかのみを判断できますが、ディレクトリ内の一部のファイルにアクセス許可が不十分な場合など、すべてのコンテンツを読み取ることができるという意味ではありません。
OpenDir()関数を通じて、ディレクトリが実際に存在するかどうかを判断するだけでなく、そのコンテンツをさらに通過することもできます。 is_dir()やfile_exists()などの他のより一般的に使用される関数がありますが、 Opendir()は、特定のシナリオでより運用的な判断方法を提供します。これらの機能を理解し、柔軟に使用すると、PHPファイルシステムを処理する能力が大幅に向上します。