我的覆盆子pi上有一个PHP网页,带有2个按钮(打开和关闭) 按钮按钮重定向到On.php 关闭按钮重定向到Off.php 在" / usr / lib / cgi-bin"我有一个我想要执行的python脚本(script.py) 我可以通过输入
从终端完美地执行它cd /usr/lib/cgi-bin
sudo python script.py
如果我从终端进行操作,它就有效。
问题是我的" / var / www"中的PHP文件(On.php)。夹。 这就是我写的:
<?php
exec('cd /usr/lib/cgi-bin');
exec('sudo python script.py');
?>
为什么脚本从终端执行,而不是从我的PHP执行?
答案 0 :(得分:14)
您不能在PHP脚本中使用sudo。 Apache正在从用户运行(www-data generaly),因此请编辑此文件:/etc/sudoers
然后添加以下行:
www-data ALL=(ALL) NOPASSWD:ALL
护理!这将授权所有函数由PHP脚本调用,您可以通过脚本或Python命令调整更改“ALL”。
然后在exec命令中确切用户:
<?php
exec('sudo -u www-data python /usr/lib/cgi-bin/script.py')
答案 1 :(得分:3)
试试这个,它应该有效:
<?php
system("cd /usr/lib/cgi-bin");
system("sudo python script.py");
?>
甚至这个:
<?php
system("cd /usr/lib/cgi-bin && sudo python script.py");
?>
答案 2 :(得分:2)
在较旧的Raspbian发行版中,您需要将文件放在/var/www/file.py
中。所以在你的file.php中添加:
{
exec("sudo python /var/www/file.py");
}
在较新的Raspbian Jessie上,您需要将文件放在/var/www/html/file.py
中,因此在您的file.php中需要添加:
{
exec("sudo python /var/www/html/file.py");
}
或者只是任何file.py
<?php
{
exec("sudo python test.py");
}
&GT;
注意:为此,您需要先编辑文件以添加这些行以允许无密码的sudo
sudo nano /etc/sudoers
然后转到底部并添加此
pi ALL=(ALL) NOPASSWD: ALL<br>
www-data ALL=(ALL) NOPASSWD: ALL