ubuntu

nginx配置防盗链的方法有哪些

小樊
36
2025-11-21 09:54:51
栏目: 编程语言

Nginx配置防盗链主要有以下几种方法:

1. 使用valid_referers指令

valid_referers指令可以用来指定允许访问资源的来源。如果请求的来源不在指定的列表中,Nginx将返回403 Forbidden状态码。

server {
    listen 80;
    server_name example.com;

    location /protected/ {
        valid_referers none blocked server_names example.com www.example.com;
        if ($invalid_referer) {
            return 403;
        }
        # 其他配置...
    }
}

2. 使用ngx_http_referer_module模块

这个模块提供了更灵活的防盗链功能,可以通过正则表达式来匹配来源。

server {
    listen 80;
    server_name example.com;

    location /protected/ {
        referer "http(s)?://(www\.)?example\.com(/.*)?";
        if ($invalid_referer) {
            return 403;
        }
        # 其他配置...
    }
}

3. 使用ngx_http_x_sendfile_module模块

这个模块可以用来防止直接访问文件,而是通过Nginx服务器来处理请求。

server {
    listen 80;
    server_name example.com;

    location /protected/ {
        x_sendfile on;
        internal;
        # 其他配置...
    }
}

4. 使用ngx_http_realip_module模块

这个模块可以用来隐藏真实的客户端IP地址,并且可以结合valid_referers指令来实现防盗链。

server {
    listen 80;
    server_name example.com;

    set_real_ip_from 192.168.1.0/24;
    real_ip_header X-Forwarded-For;

    location /protected/ {
        valid_referers none blocked server_names example.com www.example.com;
        if ($invalid_referer) {
            return 403;
        }
        # 其他配置...
    }
}

5. 使用第三方防盗链模块

有一些第三方模块可以提供更强大的防盗链功能,例如ngx_http_security_module

server {
    listen 80;
    server_name example.com;

    location /protected/ {
        security on;
        security_key "your_secret_key";
        # 其他配置...
    }
}

注意事项

  1. 性能影响:防盗链配置可能会对服务器性能产生一定影响,特别是在高并发情况下。
  2. 误判:配置不当可能会导致合法用户无法访问资源,因此需要仔细测试和调整配置。
  3. 更新:随着Nginx版本的更新,防盗链模块的功能和配置方式可能会有所变化,建议定期查看官方文档。

通过以上方法,你可以有效地防止他人盗用你的资源。根据具体需求选择合适的防盗链策略。

0
看了该问题的人还看了