这两天在做一个网站项目遇到个神奇的问题,搞得我都怀疑人生了 @。。
问题描述:
帮一个客户做了一个PHP后台的网站,结果用客户的windows主机里面的IIS建好之后,后台图片已经上传成功,但是预览访问不了,一直以为是上传文件夹权限问题,各种权限都试了一遍之后,懵B了……还是不可以,还是提示错误信息:“401 – 未授权: 由于凭据无效,访问被拒绝。”
于是查看上传目录,目录的权限已经包含”Everyone”,上传文件夹应该也没有问题。
然后一看测试的图片属性傻眼了,原来图片的属性中并不包含”Everyone”项这跟上传的目录的权限不相符啊(如果在某个目录下新建文件,那么新建的文件是继承该目录的权限的)
看到这我就想不明白了,既然目录的权限有”Everyone”项那么上传的图片的权限也应该继承父类的权限才对,所以好长时间也没有想明白这其中的原因。
因此也不知道该如何下手解决,只是在网络上漫无目的看有没有类似的问题,并按照网站的说明进行尝试。
最后在windows下使用IIS配置的PHP无法上传文件的解决方法这篇文章的帮助下成功解决了该问题。
问题总结:
在Windows平台下如果PHP使用的是IIS的话那么php在上传文件时是先将文件上传到一个临时目录下的。
(该配置项可以在php.ini的”upload_tmp_dir”里进行配置,由于我们的服务器并没有进行过配置,所以php将使用系统的临时目录”C:\Windows\Temp”)。
然后PHP再将临时目录中上传的文件再移动到你指定的目录中去。
这样就存在一个问题,即Temp目录下默认的权限是没有相应的IIS访问权限的(windows默认配置),当文件上传到该目录时那么上传的文件默认是继承了Temp目录的权限。
而PHP再将文件文件移到指定的目录时,被移动的文件并不会继承移动后所在的目录权限。
从而导致从浏览器访问被移动的文件时,因为该文件没有相应的权限(IIS访问权限)而无法访正常问。
也就出现了文件上传成功但浏览器访问时出现“401 – 未授权: 由于凭据无效,访问被拒绝。”的问题。
解决办法:
给php.ini中的upload_tmp_dir项设置一个临时目录并做好相应的权限(推荐方法)
将”C:\Windows\Temp”目录添加相应的权限
重要说明:
php.ini 的upload_tmp_dir 目录权限必须要包含IUSER和IIS_IUSERS权限或Everyone
转载请注明:木子网络 » http://www.muziwl.com