AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题

问题[capabilities](unix)

Martin Hope
Steve Wu
Asked: 2022-06-17 19:26:58 +0800 CST

为什么非 root 用户在导出的变量上调用 getenv 返回 nil

  • 1

C代码在这里:

#include <stdio.h>
#include <stdlib.h>

int main () {
   printf("PATH : %s\n", getenv("PATH"));
   printf("HOME : %s\n", getenv("HOME"));
   printf("ROOT : %s\n", getenv("ROOT"));
   printf("TMPDIR : %s\n", getenv("TMPDIR"));
   return(0);
}

做之后:

gcc env.c -o printenv
setcap 'cap_dac_override+eip' printenv
sudo -S su -s $(which bash) steve
export TMDIR=hello
./printenv

我得到了这个输出:

PATH : /sbin:/bin:/usr/sbin:/usr/bin
HOME : /home/steve
ROOT : (null)
TMPDIR : (null)

如果我删除设置为 'printenv' 的 CAP,则输出为:

PATH : /sbin:/bin:/usr/sbin:/usr/bin
HOME : /home/steve
ROOT : (null)
TMPDIR : hello

这怎么可能?

经过一番搜索,我发现了这个:http ://polarhome.com/service/man/?qf=secure_getenv&tf=2&of=RedHat&sf=

它提到这可能是由于设置功能时 getenv 变为 secure_getenv 因此所有 getenv() lib 调用都返回 nil,但是在这种情况下如何PATH打印HOME环境变量?

linux capabilities
  • 1 个回答
  • 63 Views
Martin Hope
Ekaterina
Asked: 2022-01-20 01:57:49 +0800 CST

能力是每个进程还是每个线程的属性?

  • 0

文档说功能是每个线程的属性。确实在任何

/proc/[PID]/task/[LWP]/status

我们可以找到与此线程相关的功能:

CapInh: 0000000000000000
CapPrm: 0000000000000000
CapEff: 0000000000000000
CapBnd: 0000003fffffffff
CapAmb: 0000000000000000

但与此同时,有关能力的类似信息位于

/proc/[PID]/status

所以进程,显然有它自己的能力。这让我感到困惑 - 是进程还是线程的功能属性?当执行一些需要能力的命令时,内核会检查什么集合?

posix capabilities
  • 1 个回答
  • 124 Views
Martin Hope
boredaf
Asked: 2021-11-26 07:27:11 +0800 CST

非 root 进程不能执行哪些操作?

  • 0

显然,它不能读取它没有权限的文件。但我说的是其他“动作”,我知道它们绑定到编号低于 1024 的端口。还有什么?

linux capabilities
  • 1 个回答
  • 65 Views
Martin Hope
James
Asked: 2019-04-28 08:16:02 +0800 CST

“ep”能力是什么意思?

  • 12
root@macine:~# getcap ./some_bin
./some_bin =ep

“ep”是什么意思?这个二进制文件的功能是什么?

linux capabilities
  • 2 个回答
  • 9040 Views
Martin Hope
Naftuli Kay
Asked: 2019-04-05 13:36:15 +0800 CST

setcap 二进制但带有参数?

  • 0

我正在尝试启动 BoringTun 以setcap使其无特权运行,但仍具有以下能力fmark:

root@67672793823c:/# setcap cap_net_admin+epi /usr/local/sbin/boringtun --foreground wgnet0
fatal error: Invalid argument
usage: setcap [-q] [-v] (-r|-|<caps>) <filename> [ ... (-r|-|<capsN>) <filenameN> ]

 Note <filename> must be a regular (non-symlink) file.

手册页似乎不是很有帮助,我找不到允许我执行带有任意参数的二进制文件的选项。

如果我删除参数,一切正常,但我需要传递这些参数。

linux capabilities
  • 1 个回答
  • 1990 Views
Martin Hope
John
Asked: 2019-02-20 14:23:00 +0800 CST

具有 root 用户的进程是否始终具有 Linux 中可用的所有功能?

  • 1

在 Linux 中,具有非 root 用户的进程可以分配一些功能来增加其权限。

拥有 root 用户的进程拥有所有可用的功能,但是这样的进程是否可以删除它的一些功能(手动或在某些情况下自动删除)?

linux capabilities
  • 3 个回答
  • 1123 Views
Martin Hope
AndreKR
Asked: 2018-12-15 14:53:34 +0800 CST

不推荐使用 setcap 吗?

  • 12

我正在使用systemd单元文件以非 root 用户身份启动网络服务器。

listen tcp :80: bind: permission denied即使我已经跑了,我也得到了

setcap cap_net_bind_service=+ep

在可执行文件上。

在互联网上的一个示例单元文件中,我发现

CapabilityBoundingSet=CAP_NET_BIND_SERVICE
AmbientCapabilities=CAP_NET_BIND_SERVICE

在单元文件中使用。所以我尝试了一下,突然应用程序可以绑定端口 80。

那告诉我什么?setcap是旧的/不推荐的/忽略的?仅由systemd还是由 Linux 提供?

systemd capabilities
  • 1 个回答
  • 4378 Views
Martin Hope
Sandra
Asked: 2018-11-07 04:14:57 +0800 CST

setcap CAP_SYS_TIME+ep /user/mybinaryprogram 出错

  • 0

我正在尝试使用功能(CAP_SYS_TIME),但是当我运行此命令时:

setcap CAP_SYS_TIME+ep /user/mybinaryprogram

在我的系统上,我收到以下错误:

Failed to set capabilities on file '/bin/date' (Invalid argument)
usage: setcap [-q] [-v] (-r|-|<caps>) <filename> [ ... (-r|-|<capsN>) 
<filenameN> ]
Note <filename> must be a regular (non-symlink) file.

我的系统:Linux t2080rdb 4.1.35-rt41 ppc64 GNU/Linux
我已经使用 Yocto Project SDK 2.0 获得了 linux 映像在 bin 目录中执行“ls -la”时有效,日期显示为符号链接

根据我一直在做的测试,我在尝试执行 setcap 时总是遇到同样的错误。

我解决了这个问题,该命令不起作用,因为内核没有启用“安全标签”

linux capabilities
  • 1 个回答
  • 2222 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve