我的应用程序需要做一些特权工作。我到处都在寻找,但是找不到任何有用的东西。我知道我要使用Policykit1和dbus,因为不再使用我发现的所有其他替代方法。

这是我到目前为止得到的代码:

import dbus
import os

bus = dbus.SystemBus()
proxy = bus.get_object('org.freedesktop.PolicyKit1', '/org/freedesktop/PolicyKit1/Authority')
authority = dbus.Interface(proxy, dbus_interface='org.freedesktop.PolicyKit1.Authority')

system_bus_name = bus.get_unique_name()

subject = ('system-bus-name', {'name' : system_bus_name})
action_id = 'org.freedesktop.policykit.exec'
details = {}
flags = 1            # AllowUserInteraction flag
cancellation_id = '' # No cancellation i


result = authority.CheckAuthorization(subject, action_id, details, flags, cancellation_id)

os.makedirs('/usr/local/share/somefolder')

我无法建立目录,我在做什么错?

最佳答案

文件系统安全性正在阻止您,因为您的用户没有对/usr/local/share/somefolder的写入权限。您可以使用sudo临时升级该目录创建的权限。但是,如果您需要以 super 用户身份执行更多操作,它就不会止步于此。

如果您需要写不在用户空间中的内容,则整个程序最好以root用户身份运行(当然是在sudo下),例如sudo ./myscript.py

10-04 12:35
查看更多