php[world] 2019 — 25 years of PHP

is_executable

(PHP 4, PHP 5, PHP 7)

is_executableファイルが実行可能かどうかを調べる

説明

is_executable ( string $filename ) : bool

ファイルが実行可能かどうかを調べます。

パラメータ

filename

ファイルへのパス。

返り値

ファイルが存在し、かつそれが実行可能な場合に TRUE、 エラー時に FALSE を返します。

例1 is_executable() の例

<?php

$file 
'/home/vincent/somefile.sh';

if (
is_executable($file)) {
    echo 
$file.' は実行可能です';
} else {
    echo 
$file.' は実行可能ではありません';
}

?>

エラー / 例外

失敗したときは E_WARNING が発生します。

注意

注意: この関数の結果は キャッシュされます。詳細は、clearstatcache() を参照してください。

ヒント

PHP 5.0.0 以降、この関数は、 何らかの URL ラッパーと組合せて使用することができます。 どのラッパーが stat() ファミリーをサポートしているかを調べるには サポートするプロトコル/ラッパー を参照してください。

参考

  • is_file() - 通常ファイルかどうかを調べる
  • is_link() - ファイルがシンボリックリンクかどうかを調べる

add a note add a note

User Contributed Notes 3 notes

up
9
Shyammakwana.me
2 years ago
For windows users,

It will return TRUE for EXE extensions. I have checked for MSI, but it returns FALSE.
up
0
divinity76 at gmail dot com
1 month ago
is_executable() does not check the PATH environment variable, so if your current working dir is /dir/ and you have /bin/ in your PATH env and the file /bin/ffmpeg exists, then you can still run shell_exec("ffmpeg"), but is_executable("ffmpeg") will return false.

if you're looking for a version of is_executable that also considers the PATH environment variable, then try this:

<?php

function is_executable_pathenv(string $filename): bool
{
    if (
is_executable($filename)) {
        return
true;
    }
    if (
$filename !== basename($filename)) {
        return
false;
    }
   
$paths = explode(PATH_SEPARATOR, getenv("PATH"));
    foreach (
$paths as $path) {
        if (
is_executable($path . DIRECTORY_SEPARATOR . $filename)) {
            return
true;
        }
    }
    return
false;
}
up
0
telezhkin at gmail dot com
2 months ago
Find no mention of this, but is_executable returns result for owner permissions only (not for group or other).
To Top