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 / 问题 / 1161389
Accepted
John
John
Asked: 2024-06-23 14:57:26 +0800 CST2024-06-23 14:57:26 +0800 CST 2024-06-23 14:57:26 +0800 CST

PHP shell_exec 失败,终端/CLI 正常

  • 772

我必须在 PHP 中获取有关操作系统的基本信息:

$p = shell_exec('cat /etc/*-release 2>&1');

返回:

cat: '/etc/*-release': No such file or directory

该命令通过 PuTTY 在终端/CLI 中正常运行。

我目前最好的解释是 PHP 需要设置路径。所以我尝试了这个:

$p = shell_exec('echo $PATH');

返回:

/bin:/usr/bin

echo $PATH当我直接在终端中运行时,我得到了一个:分隔列表。所以我把所有这些都直接放到了 PHP 文件中,如下所示:

putenv('/etc');

//plus others

仍然没有结果。我知道shell_exec()与其他命令配合使用效果很好shell_exec('whoami');。在终端/CLI 中,我以与 PHP 8.3 完全相同的用户身份登录。

我还遗漏了什么?

linux
  • 2 2 个回答
  • 74 Views

2 个回答

  • Voted
  1. vidarlo
    2024-06-23T16:21:12+08:002024-06-23T16:21:12+08:00

    这里有多个问题。

    1. 人们会阅读他们收到的错误信息吗?
    2. 不要使用 shell 命令将文件读入变量!使用fopen。
    3. 不要进行通配符。通配符由 shell 扩展,但 PHP 不是 shell,因此它不进行通配符。它会将您的确切命令传递给 shell,并要求 shell 执行它。是的,*-release这是一个有效的文件名。
        [~]$ ls -la /tmp/\*-releases 
        -rw-r--r-- 1 vidarlo users 0 Jun 23 10:16 /tmp/*-releases
        [~]$ 
    
    1. 通配符可能会使您遭受攻击。如果您使用通配符,您将无法控制最终读取的文件。这是一个潜在的安全问题。在这种情况下可能不是,因为您正在读取/etc,但是...
    2. 当您期望修改路径参数会改变任何内容时,您对所处环境缺乏基本的了解 - 问题不在于找不到命令cat,而是找不到您作为参数提供的文件……对平台的一般了解是编程的一个很好的起点。
    3. putenv('/etc');不是如何putenv工作的。环境变量通常是key=value-pairs。
    4. 不要把它发布到 serverfault 上。它与 IT 管理无关,它纯粹与编程有关。此外,您可能应该花一些时间来了解您正在使用的平台。
    • 1
  2. Best Answer
    John
    2024-07-03T01:45:38+08:002024-07-03T01:45:38+08:00

    问题在于 PHP 被设置为在chrootjail 中运行。我已经尝试了所有其他可能性。多亏了 @vidarlo 的评论,我才发现这一点。

    我能够通过 CageFS 插件解决 WHM 中的问题。PHP 使用的 Linux 用户被设置为执行,我将其从关联中删除。

    • 0

相关问题

  • Linux 主机到主机迁移

  • 如何在 Linux 机器上找到有关硬件的详细信息?

  • 如何在 Linux 下监控每个进程的网络 I/O 使用情况?

  • 在 RHEL4 上修改 CUPS 中的现有打印机设置

  • 为本地网络中的名称解析添加自定义 dns 条目

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