gpt4 book ai didi

python - 在/usr/bin/python2.7上使用setcap不给子任务提供权限

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:37:58 27 4
gpt4 key购买 nike

我(我们)正在(正在)使用 Python 创建数据包并捕获回复以测试网络设备。为了提供我使用的 python 功能:

sudo setcap cap_net_admin,cap_net_raw+eip /usr/bin/python2.7

当我检查功能时,设置看起来没问题:

getcap /usr/bin/python2.7
/usr/bin/python2.7 = cap_net_admin,cap_net_raw+eip

如果我运行我的脚本,我会收到以下错误:

dumpcap: The capture session could not be initiated on interface 'eth2' (You don't have permission to capture on that device).
Please check to make sure you have sufficient permissions, and that you have the proper interface or pipe specified.

如果我直接通过以下方式为 dumpcap 提供功能:

sudo setcap cap_net_admin,cap_net_raw=eip /usr/bin/dumpcap

这使脚本运行,但它并没有解决我的 python 无法使用 cap_net_admin 的问题。

有什么方法可以检查我正在运行的 python 进程是否接收到正确的功能?或者为什么 python2.7 似乎没有继承我系统上的功能?

为了确保调用正确的文件/进程,我使用/usr/bin/python2.7 作为要调用的可执行文件。相同的 python 代码适用于我公司的其他人。我正在运行 Ubuntu 16.04。问候

最佳答案

正如 @Petesh 指出的那样,您的脚本可能会调用子进程,涉及调用 exec() 并且子进程的有效集中不会提升功能。您可以通过利用环境功能来解决此问题,这些是 available for kernel 4.3+ - 即 Ubuntu 16.04 就足够了。简而言之,环境功能在 exec() 中保留,因此传递给子进程。要启动具有环境功能的进程,您可以使用以下实用程序:https://gist.github.com/tomix86/32394a43be70c337cbf1e0c0a56cbd8d

要检查给定流程的功能集,您可以使用

grep Cap /proc/[pid]/status

其中 CapEff 是有效功能集,要解码这些十六进制字符串,您可以使用 capsh

关于python - 在/usr/bin/python2.7上使用setcap不给子任务提供权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46344157/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com