首頁  >  文章  >  運維  >  IIS配置的PHP在windows下使用但無法上傳檔案的解決方法

IIS配置的PHP在windows下使用但無法上傳檔案的解決方法

黄舟
黄舟原創
2017-05-27 09:48:062223瀏覽

windows下使用IIS配置的PHP無法上傳檔,一直是很多網友比較疑惑的地方,本人蒐集整理下,希望可以幫助你們

#延續《Windows Server 2003中iis配置php》一文
伺服器上使用Apache2+PHP正常運行,換成IIS+PHP,先後出現了php.ini的環境變數無法讀取,php中驗證碼無法顯示的問題,如今又有人反應無法上傳圖片的問題。

從IIS取代Apache2的過程只是開啟IIS,關閉Apache2,其它的沒什麼變化,但是卻發生瞭如此多的差異,看樣子IIS支持PHP還是有很多要進行修改的。
分析
根據上面的描述,我懷疑問題出在IIS的權限配置上,IUSR_MACHINE的帳號對upload沒有寫入的權限,於是進行權限修改,IIS下的權限,NTFS下的權限都進行修改,但是終究都沒用,查找網絡上的資料也沒有相應的,對上傳頁面進行測試,流程為:
swf文件調用save.php上傳文件----> ;swf檔案對上傳的檔案進行重新命名--->名字傳回給save.php--->顯示出最後的名字。

現在的問題一直停留在swf對檔案重命名的這裡,一直沒有到顯示出最後的名字,並且swf檔案不參與上傳過程,那就只能在save.php檔案中進行問題查找了,在該檔案中進行測試,最後顯示的名字所使用的變數為fileName,於是插入下面的語句進行測試:
echo "fileName=2008* ****.gif";
這句話的作用就是使得fileName有值,save.php能正常顯示,先把原來的語句一句一句的進行屏蔽測試,都正常的返回了,但是當測試到:

if (mailto:!@move_uploaded_file($f[%22tmp_name"], $dest_
dir
.'/'.$fileName)) 
head
er("HTTP/1.0 404 Not Found");

文件上傳到一個臨時文件,再挪動到目的位置,那這個tmp位置在哪裡呢?是不是這個位置不可寫,
才導致了無法上傳檔案?
查找網路資料,發現php.ini下面有2個地方關於上傳的設定:
file_uploads = On 這裡設定是否允許HTTP上傳,預設應該為ON的
;upload_tmp_dir= 這裡設定上傳檔案存放的臨時位置
網路上對於這2個地方的相關資料有:

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 //这里是说php.ini文件这个地方设置成On 
upload_tmp_dir = "C:\Inetpub\wwwroot\uploads" //这个路径就是自己设置的上传文件临时存储路径 
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 
right
s 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是被注释的,没有启用,更没有设置,可是为什么Apache2却可以正常上传呢?难道问题真的出在这里?

解决
新建一个文件夹做临时上传目录,按照上面的英文说明修改php.ini中相应的那2项,把临时上传目录upload_tmp_dir设置成刚才建立的文件夹,把该文件夹的权限赋予“IUSR_计算机名”用户可写,重新启动IIS,上传试试,问题真的就这样解决了。

最终的分析答案
上面的内容写于09年,但是现在2010年7月我新增一台服务器,又出现了这个问题,同时再次按照上面的解决方法实施,在操作的过程中大概是由于哪里出了错,竟然没有成功,不得不抽出点时间来研究具体原因,找到了最终产生这个问题的原因如下。
无法上传文件,不代表所有文件都无法上传,因为我的一个网站,flash调用fwrite()传头像之类的成功了,但是调用@move_uploaded_file($f["tmp_name"], $dest_dir.'/'.$fileName)这样的函数传照片的时候仍旧无法上传。

经过我的分析,原因是由于fwrite()是传的二进制文件,而move_uploaded_file()传的是文本文件,而windows操作系统是区分这2种文件的 [参考php手册fwrite()函数的说明],这也就是说这2种不同的文件在php环境下上传时所存储的临时上传目录是不同的,由于在配置IIS环境下的PHP的时候,设置的临时目录为E:\tmp,设置该目录的iusr用户可写,二进制文件即可上传,所以我怀疑该目录就是二进制文件上传临时文件的存储位置,那么move_uploaded_file()传的文本文件的临时文件存储位置在哪里呢?其实就是在上面的那段英文里面,upload_tmp_dir设置的路径就是了,但是我的几台服务器中,每台服务器的这个设置的值都是被注释掉的“no value”,为什么有的服务器可以上传,而有的服务器不可以上传呢?这也就回到了以前我提出的问题,为什么Apache2可以上传而iis不可以上传呢?
这次我再次分析upload.php文件,分析其中造成该故障的代码具体内容如下: 

代码如下:

// 检查是否有文件上传 
if (! $_FILES['upload'.$num]['name'] == ""){ 
if ($_FILES[&#39;upload&#39;.$num][&#39;size&#39;] < $max_size) { 
1、 echo "文件上传路径:".$location.$_FILES[&#39;upload&#39;.$num][&#39;name&#39;]; 
2、echo "文件临时文件名:".$_FILES[&#39;upload&#39;.$num][&#39;tmp_name&#39;]; 
3、 move_uploaded_file($_FILES[&#39;upload&#39;.$num][&#39;tmp_name&#39;],$location.$_FILES[&#39;upload&#39;.$num][&#39;name&#39;]) or $event = "Failure"; 
} 
else
 { 
$event = "File too large!"; 
}


其中正常代码中第2句是不存在的,为了测试方便我加上来的,它的主要目的就是测试我的php.ini没有设置upload_dir_tmp的值的时候,上传的文件临时保存在哪里的,经过这个测试发现原来在不配置php.ini的upload_dir_tmp的值的时候,默认的存储位置是在C:\windows\temp目录,并且临时文件是以.tmp为后缀存储的,该文件马上就会被删除,所以你想通过操作系统的文件修改搜索功能是无法找到的,也就无法找到upload_dir_tmp的默认路径是哪里。

既然找到了upload_dir_tmp的默认路径了,那么修改c:\windows\temp的访问权限,赋予IUSR_用户可写,重启动IIS Admin服务,上传文件,终于成功了。这就是为什么我的多台服务器upload_dir_tmp的值都为空的时候有的可传,有的不可传的原因。

现在已经修改了IIS使用环境变量方式精简配置php的那篇文章了,因为当时没有注意这个位置的权限设置,造成了如今的问题,不过最终解决也是好的。

以上是IIS配置的PHP在windows下使用但無法上傳檔案的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn