我在吃覆盆子。所有文件的权限,包括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()函数作为well...Help me。
发布于 2014-06-27 21:48:35
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"," ");
?>是一种可能的解决方案
https://stackoverflow.com/questions/24461135
复制相似问题