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 / 问题 / 834252
Accepted
Jesse Rogers
Jesse Rogers
Asked: 2017-02-23 10:10:49 +0800 CST2017-02-23 10:10:49 +0800 CST 2017-02-23 10:10:49 +0800 CST

Nginx - 仅允许通过引用 URL 访问文件夹目录

  • 772

前端网络开发人员在这里。提前抱歉。

我的公司希望将我们软件的新版本存储在我们的 Web 服务器上,运行 Nginx,由WP Engine提供。

这些构建的文件路径是company.com/downloads/file.zip. 我们希望限制对该文件夹中文件的访问,除非它们来自位于我们客户登录门后面的特定引用 URL。

  • /downloads/如果用户从允许的引荐来源中单击指向内部任何文件的链接,则用户将获取文件
  • 如果用户点击任何其他来源的链接,则返回 404 或重定向到主页
  • 如果为空referer或直接访问尝试,返回404或重定向到主页

我找到了一个关于防止图像热链接的资源(我们将处理 .zip 文件),这可能对我有用,但我需要有关该语言语法的帮助。它可能有很多问题。

location ~ /downloads/$ {
valid_referers none blocked ~.allowed_domain.com;
if ($invalid_referer) {
return 404;
}
}

WP Engine 不允许我自己添加 Nginx 代码,所以我必须向他们发送我希望他们实现的代码。如果有人知道如何做到这一点并且可以帮助我,我将非常感激!

permissions nginx file-permissions hotlinking
  • 2 2 个回答
  • 9911 Views

2 个回答

  • Voted
  1. Best Answer
    Věroš K.
    2017-02-23T13:14:18+08:002017-02-23T13:14:18+08:00

    其他可能性是使用X-Accel标头。我不知道你的用例,所以它可能不合适。

    X-Accel是 nginx 特定的标头。您可以在 PHP 脚本中发出该标头 - 比如header("X-Accel-Redirect: /private-downloads/magic.iso") 当 nginx 识别此标头时,它将服务器magic.iso位于/data/private-downloads.

    因此,您的任务是准备download.php检查授权并使用X-Accel标头响应或重定向到登录屏幕。

    /private-downloads/在 nginx.conf 中的定义

    location /private-downloads/ {
        internal;    # this
        alias /data/private-downloads;
        # this should be located outside of HTTP server root
    }
    

    有关更多详细信息,请查看有关 serverfault 的 x-accel 问题。1

    • 2
  2. Věroš K.
    2017-02-23T12:25:12+08:002017-02-23T12:25:12+08:00

    您可以使用valid_referersnginx 指令。( nginx 文档)

    location /downloads/ {
        alias /var/www/downloads;
        valid_referers  www.example.me ;
    
    if ($invalid_referer) {
            return 404;
        }
    }
    

    我个人从未在生产中尝试过,因为我更喜欢使用X-Accel header。您可以在 PHP 脚本中验证您的用户,然后发送 nginx 标头 X-accel。标头将要求 nginx 通过 nginx 服务静态文件。

    • 0

相关问题

  • 如何在 Exchange 2007 中设置资源邮箱日历的忙/闲权限?

  • 共享文件夹中某些文件的访问被拒绝错误

  • Bash 脚本:要求脚本以 root 身份运行(或使用 sudo)

  • 如何授予用户安装 Windows 服务的能力?

  • 限制用户向电子邮件地址发送电子邮件

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