windows下使用IIS配置的PHP無(wú)法上傳文件的解決方法
2019-11-02 14:11:02
供稿:網(wǎng)友
延續(xù)《Windows Server 2003中iis配置php》一文
服務(wù)器上使用Apache2+PHP正常運(yùn)行,換成IIS+PHP,先后出現(xiàn)了php.ini的環(huán)境變量無(wú)法讀取,php中驗(yàn)證碼無(wú)法顯示的問(wèn)題,如今又有人反應(yīng)無(wú)法上傳圖片的問(wèn)題。
從IIS替換Apache2的過(guò)程僅僅是開(kāi)啟IIS,關(guān)閉Apache2,其它的沒(méi)什么變化,但是卻發(fā)生了如此多的差異,看樣子IIS支持PHP還是有很多要進(jìn)行修改的。
分析:
根據(jù)上面的描述,我懷疑問(wèn)題出在IIS的權(quán)限配置上,IUSR_MACHINE的帳戶(hù)對(duì)upload沒(méi)有寫(xiě)入的權(quán)限,于是進(jìn)行權(quán)限修改,IIS下的權(quán)限,NTFS下的權(quán)限都進(jìn)行修改,但是終究都沒(méi)用,查找網(wǎng)絡(luò)上的資料也沒(méi)有相應(yīng)的,對(duì)上傳頁(yè)面進(jìn)行測(cè)試,流程為:
swf文件調(diào)用save.php上傳文件---->swf文件對(duì)上傳的文件進(jìn)行重命名--->名字返回給save.php--->顯示出最后的名字。
現(xiàn)在的問(wèn)題一直停留在swf對(duì)文件重命名的這里,一直沒(méi)有到顯示出最后的名字,并且swf文件不參與上傳過(guò)程,那就只能在save.php文件中進(jìn)行問(wèn)題查找了,在該文件中進(jìn)行測(cè)試,最后顯示的名字所使用的變量為fileName,于是插入下面的語(yǔ)句進(jìn)行測(cè)試:
echo "fileName=2008*****.gif";
這句話(huà)的作用就是使得fileName有值,save.php能正常顯示,先把原來(lái)的語(yǔ)句一句一句的進(jìn)行屏蔽測(cè)試,都正常的返回了,但是當(dāng)測(cè)試到:
if (mailto:!@move_uploaded_file($f[%22tmp_name"], $dest_dir.'/'.$fileName)) header("HTTP/1.0 404 Not Found");
這句話(huà)的時(shí)候問(wèn)題出現(xiàn)了,不能上傳,查找上下文,一直沒(méi)發(fā)現(xiàn)tmp_name的變量,不過(guò)看意思是先把文件上傳到一個(gè)臨時(shí)文件,再挪動(dòng)到目的位置,那這個(gè)tmp位置在哪里呢?是不是這個(gè)位置不可寫(xiě),
才導(dǎo)致了無(wú)法上傳文件?
查找網(wǎng)上資料,發(fā)現(xiàn)php.ini下面有2個(gè)地方關(guān)于上傳的配置:
file_uploads = On 這里設(shè)置是否允許HTTP上傳,默認(rèn)應(yīng)該為ON的
;upload_tmp_dir= 這里設(shè)置上傳文件存放的臨時(shí)位置
網(wǎng)上對(duì)于這2個(gè)地方的相關(guān)資料有:
I try to set up file uploading under IIS 7 and PHP 5.
First problem was to set 2 variables in php.ini
file_uploads = On //這里是說(shuō)php.ini文件這個(gè)地方設(shè)置成On
upload_tmp_dir = "C:/Inetpub/wwwroot/uploads" //這個(gè)路徑就是自己設(shè)置的上傳文件臨時(shí)存儲(chǔ)路徑
For some reasons such directory name works,
but "upload_tmp" won't work.
The second problem was to set correct user rigths for upload folders where you try to save your file. I set my upload folder rights for the "WORKGROUP/users" for the full access. You may experiment by yourselves if you not need execute access, for example.
我的php.ini中upload_tmp_dir是被注釋的,沒(méi)有啟用,更沒(méi)有設(shè)置,可是為什么Apache2卻可以正常上傳呢?難道問(wèn)題真的出在這里?
解決:
新建一個(gè)文件夾做臨時(shí)上傳目錄,按照上面的英文說(shuō)明修改php.ini中相應(yīng)的那2項(xiàng),把臨時(shí)上傳目錄upload_tmp_dir設(shè)置成剛才建立的文件夾,把該文件夾的權(quán)限賦予“IUSR_計(jì)算機(jī)名”用戶(hù)可寫(xiě),重新啟動(dòng)IIS,上傳試試,問(wèn)題真的就這樣解決了。
最終的分析答案:
上面的內(nèi)容寫(xiě)于09年,但是現(xiàn)在2010年7月我新增一臺(tái)服務(wù)器,又出現(xiàn)了這個(gè)問(wèn)題,同時(shí)再次按照上面的解決方法實(shí)施,在操作的過(guò)程中大概是由于哪里出了錯(cuò),竟然沒(méi)有成功,不得不抽出點(diǎn)時(shí)間來(lái)研究具體原因,找到了最終產(chǎn)生這個(gè)問(wèn)題的原因如下。
無(wú)法上傳文件,不代表所有文件都無(wú)法上傳,因?yàn)槲业囊粋€(gè)網(wǎng)站,flash調(diào)用fwrite()傳頭像之類(lèi)的成功了,但是調(diào)用@move_uploaded_file($f["tmp_name"], $dest_dir.'/'.$fileName)這樣的函數(shù)傳照片的時(shí)候仍舊無(wú)法上傳。