phpshell调用
❶ ubuntu12.04 怎么用php调用shell
第一,应该查阅php.ini配置文档(我的配置文档位置是/etc/php5/php.ini),关闭安全模式 safe_mode=Off。
第二,给予php运行的用户和本机用户权限。php运行的用户名可以通过在localhost运行以下的php文件查到:
<?php
echo shell_exec("id -a");
?>123123
我的Ubuntu系统的php运行用户名是www-data(好蠢的名字…)
控制台下,执行 visudo,可以打开/etc/sudoers文件进行修改(利用visudo命令的意义在于,sudoers文件很重要,如果修改错了,visudo会提示你,而直接修改会导致系统出错,无法使用sudo…)
修改的地方在root的下一行:
‘查到的php运行的用户名’ ALL=(ALL) NOPASSWD:ALL
‘本机用户名’ ALL=(ALL) ALL
通过以上设置,应该就能完成ubuntu系统下php调用并执行shell脚本。
PS.相关的命令(详细请网络google之)
$output = shell_exec("xxx.sh");//只有失败的时候返回NULL
system("cmd string",$status);//$ststus在调用成功时返回true,失败返回false
❷ 如何使用PHP调用SHELL命令调用后并且执行SHELL命令
解除sysyem() passthru() exec()等函数禁用。
执行passthru('ps -ef');可以得到这条命令的输出内容。正则得到所需内容,然后再调用这些函数执行操作。具体用法翻翻手册。
❸ PHP调用shell命令,怎么实现,我为什么shell_exec的返回值总是null呢
是权限问题,php默认的用户没有权限执行shell
❹ 如何让php执行shell
php给我们提供了system(),exec(),passthru()这三个函数来调用外部的命令.
虽然这三个命令都能执行linux系统的shell命令,但是其实他们是有区别的:
system() 输出并返回最后一行shell结果。
exec() 不输出结果,返回最后一行shell结果,所有结果可以保存到一个返回的数组里面。
passthru() 只调用命令,把命令的运行结果原样地直接输出到标准输出设备上。
相同点:都可以获得命令执行的状态码
例子:system("/usr/local/bin/webalizer/webalizer");
❺ 解析php中如何直接执行SHELL
本篇文章是对php中直接执行SHELL的方法进行了详细的分析介绍,需要的朋友参考下 $message=shell_exec("sudo /usr/local/webserver/nginx/sbin/nginx -t 2>&1"); echo "运行结果:".$message.""; 上面的语句可以直接在PHP中执行SHELL语句 如果有返回值 那么其中的 2>&1 是必须的 他会重定向输出strerr 转到strout 输出!否则返回结果会为空!
❻ 如何通过php页面执行shell脚本
检查一下,shell脚本的执行权限。
修改一下可执行权限测试看看:
sudo chmod a+x filename.sh