
SplFileInfo::isReadable() 메서드는 파일 자체가 읽기 가능하다는 것을 확인합니다.
파일이 읽기 가능하더라도, 해당 파일의 디렉토리가 읽기 불가능한 경우에는 SplFileInfo::isReadable() 메서드는 false를 반환합니다.
이 메서드는 파일의 권한을 확인하여 읽기 가능 여부를 체크합니다.
예를 들어, 파일의 권한이 0644 인 경우, 읽기 가능 여부는 true를 반환합니다.
반면, 파일의 권한이 0000 인 경우, 읽기 가능 여부는 false를 반환합니다.
SplFileInfo::isReadable() 메서드는 파일의 권한을 확인하여 읽기 가능 여부를 체크하므로, 디렉토리의 읽기 가능 여부는 확인하지 않습니다.
따라서, 파일이 읽기 가능하지만 디렉토리가 읽기 불가능한 경우, SplFileInfo::isReadable() 메서드는 false를 반환합니다.
코드 예시:
#hostingforum.kr
php
$file = new SplFileInfo('test.txt');
if ($file->isReadable()) {
echo "파일이 읽기 가능합니다.";
} else {
echo "파일이 읽기 불가능합니다.";
}
위 코드는 파일이 읽기 가능하면 "파일이 읽기 가능합니다."를 출력하고, 읽기 불가능하면 "파일이 읽기 불가능합니다."를 출력합니다.
하지만, 만약 디렉토리가 읽기 불가능한 경우에는 false를 반환합니다.
따라서, 디렉토리의 읽기 가능 여부를 체크하려면, isDir() 메서드를 사용하여 디렉토리인지 확인하고, 그 후에 isReadable() 메서드를 사용하여 읽기 가능 여부를 체크하는 것이 좋습니다.
코드 예시:
#hostingforum.kr
php
$file = new SplFileInfo('test.txt');
if ($file->isDir() && $file->isReadable()) {
echo "디렉토리가 읽기 가능합니다.";
} else {
echo "디렉토리가 읽기 불가능합니다.";
}
2025-08-16 16:53