为什么在服务器上php里执行file_put_contents创建文件返回是false呢,文件目录已经设置为777的权限了,不解

WBOY
發布: 2016-06-23 14:01:04
原創
3834 人瀏覽過

想用file_get_contents读取网络上的图片文件并由file_put_contesnts写入到服务器本地,file_get_contesnts执行没问题,可以读取信息,然后将读出的数据$data执行:
var_dump(file_put_contents($local_file_position, $data));在测试中会显示var_dump出的信息,但最后file_put_contents返回是false,不知道为什么,在网上搜说是aparche没有写权限,是这样的吗?如果是,如何设置呢?

环境:CentOS 6.5 + MySQL5.5.35 + tomcat7.0.47


回复讨论(解决方案)

补充一下,要写入的文件所在路径的权限已经设置为777

用的是绝对路径还是相对路径?

绝对路径和相对路径是一样的

先确认file_get_contents()获取的数据是否存在,数据类型是否合法。

这个已经确认数据是存在的,数据就是字符串,即使我用fopen 和fwrite也是存在问题。

估计是权限不够
echo substr(sprintf('%o', fileperms('你的目录')), -4); //看看是什么结果

绝对路径和相对路径是一样的
要求能写入的话 文件所在的目录也是需要有写的权限的
比如 /home/centos/123.txt
目录home、centos也都是需要写的权限的不只是单单123.txt需要写权限

估计是权限不够
echo substr(sprintf('%o', fileperms('你的目录')), -4); //看看是什么结果

返回0755

估计是权限不够
echo substr(sprintf('%o', fileperms('你的目录')), -4); //看看是什么结果

我修改成了777,执行返回:

0777

file_put_contents 失败时会有明确的错误信息输出
请贴出

php文件t.php放在目录(绝对路径)/usr/local/www/wxtest
$fp=fopen('txt/test.txt', 'wb');
if($fp) fwrite($fp, "TESTSETST");
else echo "fail to create file. 
";
fclose($fp);
?>

在windows浏览器地址直接输入该php文件
执行结果如下:
Warning: fopen(txt/test.txt): failed to open stream: Permission denied in /usr/local/www/wxtest/t.php on line 87 fail to create file. 
Warning: fclose() expects parameter 1 to be resource, boolean given in /usr/local/www/wxtest/t.php on line 90 

提示很清楚了,
Permission denied 
拒绝访问

你是要把文件写到 /usr/local/www/wxtest/txt 目录中
请检查目录存在且可写

目录的权限已经设置成了777权限。
并且防止上级目录权限不足,我把/usr/local/www/wxtest/txt所有目录都设置成了755,都包含写权限,还是不行。

1. 755权限指的是 rwxr-xr-x, 同组和其他用户是没有写权限的。 777才是全部用户拥有所有权限。

2. 建议使用绝对路径,写文件前在脚本内判断路径是否存在,不存在则先创建路径(目录)再写文件,这个是血淋淋的教训。

1. 755权限指的是 rwxr-xr-x, 同组和其他用户是没有写权限的。 777才是全部用户拥有所有权限。

2. 建议使用绝对路径,写文件前在脚本内判断路径是否存在,不存在则先创建路径(目录)再写文件,这个是血淋淋的教训。

权限修改为 777  也不行啊。路径肯定是存在的。

把/usr/local/www/wxtest/txt设成777

把/usr/local/www/wxtest/txt设成777

把/usr/local/www/wxtest/txt设成777

已经设置成了777

是不是apache里面还有需要设置的,或是系统里面那个地方还需要设置?

确定是对组外用户的权限是777?

确定是对组外用户的权限是777?

组外用户不就是other组吗?你指的是什么?

呵呵,解决了,结贴,谢谢各位的帮忙!

呵呵,解决了,结贴,谢谢各位的帮忙!
怎么解决的 可否分享下


呵呵,解决了,结贴,谢谢各位的帮忙!
怎么解决的 可否分享下

默认下selinux是开启的
查看SELinux状态:
1、/usr/sbin/sestatus -v      ##如果SELinux status参数为enabled即为开启状态
SELinux status:                 enabled
2、getenforce                 ##也可以用这个命令检查
关闭SELinux:
1、临时关闭(不用重启机器):
setenforce 0                  ##设置SELinux 成为permissive模式
                              ##setenforce 1 设置SELinux 成为enforcing模式
2、修改配置文件需要重启机器:
修改/etc/selinux/config 文件
将SELINUX=enforcing改为SELINUX=disabled
重启机器即可

另外,如果以上还是不能解决的话要设置一下目录的权限策略
chcon -R -t httpd_sys_content_t /home/html

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板