在python中使用导入的模块会导致权限被拒绝错误

时间:2018-08-30 16:49:21

标签: python import permissions pip

我正在尝试在python脚本中使用导入的模块(pylightning),该脚本使用用户www-data下的apache运行。

当以用户www-data的身份通过apache运行时,脚本给出了权限错误:

File "/usr/local/lib/python3.4/dist-packages/lightning/lightning.py", line 69, in call
sock.connect(self.socket_path)
PermissionError: [Errno 13] Permission denied

要解决此问题,我进行了深入搜索,发现我需要以www-data用户身份重新安装该模块:

sudo pip3 uninstall pylightning
sudo -H -u www-data pip3 install pylightning

该脚本仍可以以常规用户的身份从CLI顺利运行:

$python3 index.py
Content-Type: text/html


<html><body>
etc...

但是从apache(通过浏览器或作为用户www-data的命令行)仍然会出现相同的错误:

$sudo -u www-data python3 /var/www/html/index.py
Content-Type: text/html


<html><body>
Traceback (most recent call last):
File "/var/www/html/index.py", line 29, in <module>
print(rpc_interface.listpeers())
File "/usr/local/lib/python3.4/dist-packages/lightning/lightning.py", line 345, in listpeers
return self.call("listpeers", payload)
File "/usr/local/lib/python3.4/dist-packages/lightning/lightning.py", line 69, in call
sock.connect(self.socket_path)
PermissionError: [Errno 13] Permission denied

这里有人知道吗?

脚本源:

#!/usr/bin/env python3

import hashlib
from lightning.lightning import LightningRpc

rpc_interface = LightningRpc("/home/pi/.lightning/lightning-rpc")
print ("Content-Type: text/html\n\n");
print ("</body></html>asd");
print(rpc_interface.listpeers())

此行触发错误:     打印(rpc_interface.listpeers())

1 个答案:

答案 0 :(得分:0)

验证www数据用户是否有权访问/home/pi/.lightning/lightning-rpc(包括父目录)。