我正在吃覆盆子。所有文件的权限,包括python脚本,如下所示:
#!/usr/bin/python
from time import sleep
import RPi.GPIO as GPIO
GPIO.setmode(GPIO.BOARD)
GPIO.setup(11, GPIO.OUT)
GPIO.output(11, False)
sleep(0.4)
GPIO.output(11, True)
sleep(1.6)
GPIO.output(11, False)
sleep(1)
全部归www-data
所有,所有文件都设置为777(是的,我知道这不聪明,但我正试图解决这个问题。)
它使用sudo运行,我的visudo文件在这里:
www-data ALL=(ALL) NOPASSWD: /var/www/gateopener.py /usr/bin/python /bin/chmod
这是PHP ......
<?php
if (($_POST["safe2"]) != "good") {
header("Location: http://xx.xxx.xx.xxx/index.html");
}
ignore_user_abort(true);
set_time_limit(0);
`/usr/bin/sudo /var/www/gateopener.py`;
?>
现在有人告诉我为什么这不起作用?我尝试了不同的变体(EI使用不同的权限移动文件。)。我也尝试过使用php的exec()
功能......请帮帮我。
答案 0 :(得分:0)
<强> run_me_as_daemon.py 强>
#!/usr/bin/python
from time import sleep
import RPi.GPIO as GPIO
import os
while True:
if not os.path.exists("open_gate.txt"):continue
os.remove("open_gate.txt") # FILE DELETE !!! so we dont re-enter
with open("log.txt","w") as f:
print >>f,"Opening GATE @ %s"%(time.strftime("%x %X"),)
GPIO.setmode(GPIO.BOARD)
print >>f, "Set Mode To %s"%(GPIO.BOARD,)
GPIO.setup(11, GPIO.OUT)
print >>f, "SET 11 to %s"%(GPIO.OUT)
GPIO.output(11, False)
print >> f,"output low signal 11"
sleep(0.4)
GPIO.output(11, True)
print >> f,"output high signal to 11"
sleep(1.6)
GPIO.output(11, False)
print >> f,"output low signal 11"
sleep(1)
print >> f,"Competed TASK"
<强>的index.php 强>
<?php
if (($_POST["safe2"]) != "good") {
header("Location: http://xx.xxx.xx.xxx/index.html");
}
file_put_contents("open_gate.txt"," ");
?>
是一种可能的解决方案