ファイルパーミッションの確認の仕方
<?php $perms = fileperms('/etc/passwd'); if (($perms & 0xC000) == 0xC000) { // ソケット $info = 's'; } elseif (($perms & 0xA000) == 0xA000) { // シンボリックリンク $info = 'l'; } elseif (($perms & 0x8000) == 0x8000) { // 通常のファイル $info = '-'; } elseif (($perms & 0x6000) == 0x6000) { // ブロックスペシャルファイル $info = 'b'; } elseif (($perms & 0x4000) == 0x4000) { // ディレクトリ $info = 'd'; } elseif (($perms & 0x2000) == 0x2000) { // キャラクタスペシャルファイル $info = 'c'; } elseif (($perms & 0x1000) == 0x1000) { // FIFO パイプ $info = 'p'; } else { // 不明 $info = 'u'; } // 所有者 $info .= (($perms & 0x0100) ? 'r' : '-'); $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0040) ? (($perms & 0x0800) ? 's' : 'x' ) : (($perms & 0x0800) ? 'S' : '-')); // グループ $info .= (($perms & 0x0020) ? 'r' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0008) ? (($perms & 0x0400) ? 's' : 'x' ) : (($perms & 0x0400) ? 'S' : '-')); // 全体 $info .= (($perms & 0x0004) ? 'r' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); $info .= (($perms & 0x0001) ? (($perms & 0x0200) ? 't' : 'x' ) : (($perms & 0x0200) ? 'T' : '-')); echo $info; ?>
書き込み属性だけを確認したければ、以下でとれる。
$perms=substr(sprintf('%o', fileperms($target_file)), -4); $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); if( $info=='www' ){ echo 'OK'; }else{ echo '書き込みできません'; }切り出しモジュール
//********************************************************************** function wp_Yuzulib_permcheck($file) //********************************************************************** { $perms=fileperms($file); /* パーミッションの所有者、グループ、その他はの読み、書き、実行は、3BITづつ */ $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); return($info); }
スポンサーリンク