相信大家也遇到过,php程序运行时产生了一个daemon的用户,而这个用户不具备写文件的权限,我试过如下几种方法:
1、chmod函数 chmod($file, 0777),无效
2、exec函数 exec("chmod -R 777 $file"),无效
将它们改成755也不行,查过很多资料说不具备超级用户权限,但为了安全,服务器生成的这个daemon用户是没有超级用户权限的,应该如何修改,请给出具体步骤,参照了很多资料并执行其中代码都没有效果
在php教程中调用linux命令的函数是
string exec(string command, string [array], int [return_var]);
如
exec( "vpopmail ");
echo exec('whoami');
再看一实例
function exec_enabled() {还有一种命令是
php通过函数system()调用系统命令。
string system ( string $command [, int &$return_var ] )实例
system('asterisk -vvvvvvvvvvvc');system()是一样的函数C的,它执行给定的命令和输出结果的版本。该system()的调用也尝试自动刷新网页服务器的输出缓冲器在每个输出
行如果PHP运行作为服务器模块。如果你需要执行一个命令,并已全部通过直接从背面没有任何干扰的命令数据,使用passthru()函数。
php调用linux命令的权限问题
你可以使用定时任务执行你要调用的php,这时的权限就是root,
php通过函数system()调用系统命令
php一般是以apache用户身份去执行的,把apache加入到存储你文件的父文件夹属组里去,然后改该父文件夹权限为775,这样属组成员就有写的
权限,而apache属于这个组就可以改写该目录下所有文件的权限,当然,属组最好不要是root,你可以为该文件夹改个其它普通用户组。
改apache/php的运行用户方法不安全