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 / 问题 / 463243
Accepted
Lekensteyn
Lekensteyn
Asked: 2013-01-06 03:02:11 +0800 CST2013-01-06 03:02:11 +0800 CST 2013-01-06 03:02:11 +0800 CST

如何在将不可读文件传递给 fastcgi 后端之前检查是否存在不可读文件?

  • 772

我有几个 PHP 站点,我想在权限方面将它们分开。因此,我创建了一个新用户并为这些用户设置了一个 PHP 池。考虑以下配置:

  • PHP-FPM 以用户身份运行php
  • nginx 以用户身份运行nginx
  • webroot 是/srv/http,可由 php 和 nginx 访问。
  • 该文件/srv/http/index.php可由php读取,但不可由nginx读取。
  • 该文件fastcgi_stuff包含用于设置标头、设置后端等的基本 fastcgi 参数。假设静态文件和 PHP 文件的 webroot 相同。

下面的 nginx.conf 包含了这个配置的要点,它被放在一个server指令中:

server_name example.com;
root /srv/http;

index index.php;
location ~ \.php$ {
    include fastcgi_stuff;
}

如果我请求http://example.com/上述配置,页面将按预期加载。对于http://example.com/does.not.exist,我得到了预期的 404。

为了防止将不存在的文件传递给 PHP-FPM,我尝试添加以下行之一:

    try_files $uri =404;
    if ( !-e $request_filename ){ return 404; }

两者都不像宣传的那样工作,它试图打开文件而不是通过stat()调用检查文件是否存在。我通过检查源代码并strace在工作进程上运行来确认这一点。

这是我遇到麻烦的一个基本情况,另一种情况是我隐藏了扩展名,因此将 atry_files $uri.php =404放在位置块中。有什么建议么?

nginx
  • 1 1 个回答
  • 604 Views

1 个回答

  • Voted
  1. Best Answer
    Lekensteyn
    2013-01-06T05:03:13+08:002013-01-06T05:03:13+08:00

    Nginx 尝试打开文件,因为我有disable_symlinks on;. 相关源码在core/ngx_open_file_cache.c, functionngx_file_info_wrapper中。(称为来自ngx_open_cached_file,来自ngx_http_script_file_code)。

    如果disable_symlinks设置为off,nginx 会执行一个简单的统计调用(在 *nix 上被定义为 typedef)ngx_file_info。stat当disable_symlinks设置为其他内容(例如on)时,它会尝试以一种对符号链接竞争安全的方式打开文件,然后fstat()对打开的文件描述符执行调用。由于 nginx无法打开文件进行读取,因为它没有权限,因此它失败了。

    短期解决方案是再次使用启用符号链接disable_symlinks off,长期解决方案是修改函数以遍历包含目录,然后遍历该目录fstatat()中的文件。请记住为不包含 PHP 脚本但可由 PHP 用户写入的目录禁用符号链接。


    如http://forum.nginx.org/read.php?2,225152,234724#msg-234724所述,此行为已记录:

    在不支持打开目录仅供搜索的系统上,使用这些参数要求工作进程对所有检查的目录具有读取权限。

    我已经上传了一个补丁,允许您限制符号链接并且仍然可以try_files正常if工作。另请参阅上面的链接线程。

    • 1

相关问题

  • Gzip 与反向代理缓存

  • nginx 作为代理的行为

  • Nginx 学习资源 [关闭]

  • 提供 70,000 个静态文件 (jpg) 的最佳方式?

  • 在 Apache、LightTPD 和 Nginx Web 服务器上提供 PHP 5.x 应用程序的现状?

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