|
由于服務(wù)器端的php.ini我們無法操縱,當(dāng)用ini_set()也關(guān)閉不了safe mode模式,我們只有退而求其次,找一個(gè)更可靠、安全的檢測(cè)方法來檢測(cè)文件是否存在。我們可以借助 $_server['document_root'] 來加以實(shí)現(xiàn)。$_server['document_root'] 返回的是網(wǎng)站的根目錄,該目錄的最后一個(gè)子目錄不包含目錄標(biāo)志符號(hào)“/”,如:
d:/www/htdocs
有了根目錄,再加上需要檢測(cè)的文件的路徑,我們將得到一個(gè)絕對(duì)的路徑,php就可以順利使用file_exists()函數(shù)對(duì)之進(jìn)行檢測(cè)。上述代碼我們只需要更改第一行為(注意,我們?cè)赾onfig.php之前加上了符號(hào)“/”):
$file=$_server['document_root']."/config.php";
如此,代碼的執(zhí)行就很可信,不會(huì)出現(xiàn)預(yù)期以外的結(jié)果。
以上方法同樣適用于目錄(is_dir())或文件(is_file())的相關(guān)檢測(cè)函數(shù),能夠檢測(cè)出被安全保護(hù)的目錄或文件是否存在。
最后順便提一下:這類被php特殊設(shè)置所保護(hù)的文件在引用(include和require)時(shí)不必加上$_server['document_root']路徑,因?yàn)椋鶕?jù)php說明文檔,它們是允許引用的。
方法2:本人的情況是因?yàn)槲募趙indows和linux之間來回的移動(dòng)。造成linux下文件和目錄的訪問權(quán)限被改變,導(dǎo)致出文件除擁有者外其他均無訪問權(quán)限。使用chmod -r 755 xxx/* 解決了問題。
php技術(shù):解析php file_exists無效的解決辦法,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。