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 / 问题

问题[ghost-blog](server)

Martin Hope
pk192837465
Asked: 2020-10-10 10:44:07 +0800 CST

在运行 Ghost 的 nginx 上阻止图像热链接也会破坏有效域上的图像

  • 1

我在 nginx 1.14.0 和 Ubuntu 18.04 上运行 Ghost。我正在尝试阻止外部站点的图像盗链。

我已经从这篇文章中添加了推荐的代码(以 location ~* .(gif|png|jpe?g)$ 开头)以防止图像盗链。

这是我的站点配置文件:

server {
listen 443 ssl http2;
listen [::]:443 ssl http2;

server_name example.com;
root /var/www/example.com/system/nginx-root; # Used for acme.sh SSL verification (https://acme.sh)

ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
include /etc/nginx/snippets/ssl-params.conf;

location / {
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header Host $http_host;
    proxy_pass http://127.0.0.1:2368;
}

location ~* \.(gif|png|jpe?g)$ {
    valid_referers none blocked example.com *.example.com;
    if ($invalid_referer) {
        return 403;
    }
}

location ~ /.well-known {
    allow all;
}

client_max_body_size 50m;}

问题是当我添加此代码块并重新启动 nginx 时,它可以正常工作并阻止返回 403 Forbidden 错误的外部请求。但是,当我在 Firefox 中使用网络检查器检查请求时,尽管引用者似乎来自https://example.com域,但它也会破坏图像的本地显示。

我尝试将不同的服务器添加到 valid_referers 行:localhost、127.0.0.1、服务器的 ip、https : //example.com/*、http: //example.com/*。然而,无论我如何配置 valid_referers 行,当尝试从本地站点加载图像时,图像仍然被阻止。

当我删除整个热链接阻止块时,本地一切正常,并且图像能够被热链接。

有任何想法吗?这让我快疯了。提前致谢。

nginx hotlinking ghost-blog
  • 1 个回答
  • 239 Views
Martin Hope
polymath
Asked: 2020-09-07 02:19:28 +0800 CST

单击子目录 proxy_pass 中的链接返回 404 NGINX

  • 0

好的,我会尽力解释这一点。我已成功设置到服务器块(网站 A)/blog/上的子目录位置,该位置成功在子域服务器块(网站 B)example.com上显示我的博客,网址为.blog.example.com.auexample.com/blog/

但是,当我单击主页上的任何链接example.com/blog/时,当它应该链接到网站 B 上的文章时,它会显示网站 A 的 404。

期望的行为: 显示时example.com/blog/article的链接blog.example.com/articleexample.com/blog/article

实际行为: 显示404时example.com/blog/article的链接example.com/articleexample.com/article

我想确保出现在通过位置块/blog/传递到网站 B 的每个请求上。/blog/

这是我当前的网站 A 为网站 B 上的博客提供服务的服务器块:

server {
  server_name example.com;

...

  location ^~ /blog/ {
      proxy_pass https://blog.example.com.au/;
      proxy_set_header Host blog.example.com.au;
  }

  # This is needed to correctly serve static files for Website B and not have same 404 behaviour as explained above
  location /assets/ {
     proxy_pass https://blog.example.com.au/assets/; 
}

  # This is needed to correctly serve static files for Website B and not have same 404 behaviour as explained above
  location /content/ {
    proxy_pass http://blog.example.com.au/content/;
  }
}

如果它有助于网站 A 和 B 都被反向代理并在同一个 conf 文件中完美地工作:

upstream Website_A {
  server Website_A:8000;
}

upstream Website_B {
    server Website_B:2368;
}

...
nginx reverse-proxy ghost-blog
  • 1 个回答
  • 477 Views

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