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 / 问题 / 410056
Accepted
Peter
Peter
Asked: 2017-12-11 06:28:14 +0800 CST2017-12-11 06:28:14 +0800 CST 2017-12-11 06:28:14 +0800 CST

简而言之,OpenBSD 的承诺是什么?

  • 772

有人可以描述一下,对于非程序员但 IT 人员,什么是承诺?

例如:有一个程序,例如:“xterm”。质押如何使其更安全?它承诺在程序代码内部,还是在操作系统本身外部?

质押在哪里?是否在程序代码中;或者操作系统是否有一个只能调用 xy 系统调用的二进制文件列表?

security openbsd
  • 3 3 个回答
  • 4670 Views

3 个回答

  • Voted
  1. Best Answer
    arif
    2017-12-16T14:08:54+08:002017-12-16T14:08:54+08:00

    什么是质押?

    pledge是系统调用。

    调用pledge程序就是承诺程序只会使用某些资源。

    另一种说法是将程序的操作限制为其需要,例如,

    “我保证不使用任何其他端口,除了port 63”
    “我保证不使用任何其他系统调用,除了lseek()和fork()”

    它如何使程序更安全?

    它限制了程序的运行。例子:

    • 您编写了一个名为xyz只需要read系统调用的程序。
    • 然后你添加pledge只使用read但没有别的。
    • 然后一个恶意用户发现在你的程序中存在一个可以调用rootshell 的漏洞。
    • 利用你的程序打开一个rootshell将导致内核将终止进程SIGABRT(不能被捕获/忽略)并生成一个日志(你可以找到dmesg)。

    这是因为在执行程序的其他代码之前,它首先不使用系统调用pledge以外的任何东西。read但是打开rootshell 会调用其他几个系统调用,这是被禁止的,因为它已经承诺不使用任何其他但read.

    誓约在哪里?

    它通常在一个程序中。OpenBSD 6.5 手册页中的用法:

    #include <unistd.h>
    
    int pledge(const char *promises, const char *execpromises);
    

    示例代码:来自cat.ccat的命令示例代码

    ........
    #include <unistd.h>
    ........
    int ch;
    if (pledge("stdio rpath", NULL) == -1)
        err(1, "pledge");
    
    while ((ch = getopt(argc, argv, "benstuv")) != -1)
    ..........
    
    • 18
  2. Johan Myréen
    2017-12-11T07:51:43+08:002017-12-11T07:51:43+08:00

    程序通常只使用一组特定的系统或库调用。您可以将pledge允许的系统调用集限制为仅此集。例如,如果程序不需要读取密码数据库,您可以禁止调用该getpwnam()函数。

    这有什么用?这是针对漏洞的额外防线。如果程序包含错误,那么有人可能会利用该错误来改变程序的执行流程或向进程中注入一些额外的代码。例如,该错误可能是面向网络的守护程序中的缓冲区溢出错误,攻击者可以通过向程序发送超出其处理能力的数据来触发该错误,可能会安排程序/etc/passwd通过网络。

    • 6
  3. Neil McGuigan
    2017-12-13T11:35:38+08:002017-12-13T11:35:38+08:00

    您的程序“承诺”只使用功能 {A,B,C}

    如果黑客可以将代码注入您的承诺进程并尝试功能 D,那么操作系统会使您的程序崩溃

    例如,假设您有一个 NTP 服务器。它承诺只使用 DNS 和 CLOCK 功能。但它有一个允许远程代码执行的缺陷。黑客要求它写入文件。但pledge会检测到这一点并关闭程序并记录错误

    • 5

相关问题

  • cpg 在磁盘分区安装 OpenBSD 时是什么意思?

  • 加强 rhel6/7 服务器的安全性 [关闭]

  • 如果某人被授予 root 访问权限,是否可以劫持服务器作为人质?[关闭]

  • 如何跟上 OpenBSD 的潮流?

  • 是否有实现 RFC 5848“签名系统日志消息”的系统日志守护程序?

Sidebar

Stats

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

    JSON数组使用jq来bash变量

    • 4 个回答
  • Marko Smith

    日期可以为 GMT 时区格式化当前时间吗?[复制]

    • 2 个回答
  • Marko Smith

    bash + 通过 bash 脚本从文件中读取变量和值

    • 4 个回答
  • Marko Smith

    如何复制目录并在同一命令中重命名它?

    • 4 个回答
  • Marko Smith

    ssh 连接。X11 连接因身份验证错误而被拒绝

    • 3 个回答
  • Marko Smith

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

    • 7 个回答
  • Marko Smith

    systemctl 命令在 RHEL 6 中不起作用

    • 3 个回答
  • Marko Smith

    rsync 端口 22 和 873 使用

    • 2 个回答
  • Marko Smith

    以 100% 的利用率捕捉 /dev/loop -- 没有可用空间

    • 1 个回答
  • Marko Smith

    jq 打印子对象中所有的键和值

    • 2 个回答
  • Martin Hope
    EHerman JSON数组使用jq来bash变量 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux 日期可以为 GMT 时区格式化当前时间吗?[复制] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC 如何复制目录并在同一命令中重命名它? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve “root”用户的文件权限如何工作? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe 将默认编辑器更改为 vim for _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey 如何下载软件包而不是使用 apt-get 命令安装它? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao 为什么目录 /home、/usr、/var 等都具有相同的 inode 编号 (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg —list-keys 命令在将私钥导入全新安装后输出 uid [未知] 2017-11-26 18:26:02 +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