我發(fā)現(xiàn)了一個(gè)問題,今天與大家分享。我把整個(gè)過程描述一下。 問題 公司有個(gè)框架是基于smarty寫的,我負(fù)責(zé)php的升級(jí),維護(hù)人員把新環(huán)境布上來之后,測(cè)試人員找我提出經(jīng)常報(bào)錯(cuò)(錯(cuò)誤:提示找不到文件的)。我追蹤了一下代碼,原來是smarty的這個(gè)地方報(bào)的錯(cuò)誤。 錯(cuò)誤:這里報(bào)出文件不存在。 思考過程: 1、我原以為是程序里沒有這個(gè)文件呢,結(jié)果發(fā)現(xiàn),文件是有的,那是怎么回事? 2、后來我再猜是不是php內(nèi)核有問題,我把php的相關(guān)內(nèi)核文件看了一遍,也沒發(fā)現(xiàn)問題。結(jié)果我就把整個(gè)過程跟項(xiàng)目經(jīng)理說去了?!虑橐矝]解決,就這樣先不了了之。升級(jí)的事情先耽誤著。 今天又發(fā)現(xiàn)這個(gè)問題,我第一反應(yīng)是php版本是不是升級(jí)了,發(fā)現(xiàn)沒有?!髞戆颜麄€(gè)目錄設(shè)置成777就沒事了(chmod 777 -R 目錄)。我想是不是file_exists()方法問題。 所以,我就進(jìn)行了相關(guān)的調(diào)試和實(shí)驗(yàn)。 調(diào)試過程 調(diào)試代碼: 目錄: 觀察各個(gè)權(quán)限:test對(duì)www是沒有任何權(quán)限的,而執(zhí)行文件index.php有讀寫執(zhí)行權(quán)限,包含文件test.txt有讀寫權(quán)限。 運(yùn)行結(jié)果: 目錄的執(zhí)行權(quán)限影響file_exists() 1、給test一個(gè)最大的權(quán)限——755 既然成功了,說明file_exists()函數(shù)是受目錄權(quán)限的限制的。 那什么樣的目錄權(quán)限影響file_exists()呢? 我做了幾個(gè)實(shí)驗(yàn): 1、文件的任何上級(jí)目錄,只有寫權(quán)限時(shí)報(bào)文件不存在; 2、文件的任何上級(jí)目錄,只有讀權(quán)限時(shí)也報(bào)文件不存在; 3、而當(dāng)所有上級(jí)目錄都有執(zhí)行權(quán)限的時(shí)候,報(bào)文件是存在的,一切都正常。 結(jié)果,說明file_exists()在判斷文件是否存在的時(shí)候是遞歸判斷每個(gè)目錄是不是有執(zhí)行權(quán)限。 修改文件路徑為相對(duì)路徑,得出一樣的結(jié)果。 總結(jié) 在php手冊(cè)上并沒有提到,file_exists會(huì)受目錄的執(zhí)行權(quán)限影響。今通過此文告知那些也有這方面問題的開發(fā)者。僅以此為戒。 附加信息 感謝大家留的言,非常有用。經(jīng)過大家的意見我再查了下手冊(cè),確實(shí),如果目錄沒有執(zhí)行權(quán)限,php-fpm應(yīng)用進(jìn)程就不能到這個(gè)目錄下面去進(jìn)行文件搜索,當(dāng)然就認(rèn)為文件不存在(實(shí)際是認(rèn)為沒有可執(zhí)行的目錄是不存在的)。 手冊(cè)內(nèi)容,大家可以一起斟酌一下,主要是執(zhí)行權(quán)限。在這里就不詳談讀寫權(quán)限了(一般都很好理解)。 明顯手冊(cè)中,對(duì)目錄的執(zhí)行權(quán)限有明確的指示。對(duì)目錄的執(zhí)行權(quán)限,就是擁有被搜索的權(quán)利。 推薦 如果這篇文章對(duì)你有所幫助,或者也讓你解決了此類問題,請(qǐng)推薦一把,讓哥們有更強(qiáng)的寫作動(dòng)力。 原文鏈接:http://www.cnblogs.com/baochuan/archive/2012/05/06/2445822.html 【編輯推薦】 【責(zé)任編輯:張偉 TEL:(010)68476606】
|
|