Nginx 防盗链配置

本文介绍了如何通过Nginx的ngx_http_referer_module模块设置合法引用域,阻挡来源非法的请求,并举例配置了location块以实现404响应。重点讲解了valid_referers和if条件的使用,以及server_names和*.youdomain.com的示例应用。
摘要由CSDN通过智能技术生成

nginx模块ngx_http_referer_module通常用于阻挡来源非法的域名请求。


(1) 定义合规的引用
valid_referers none | blocked | server_names | string ...;
(2) 拒绝不合规的引用
if  ($invalid_referer) {
    rewrite ^/.*$ http://www.b.org/403.html 
}

none                     # 意思是不存在的Referer头(表示空的,也就是直接访问,比如直接在浏览器打开一个图片)
blocked                # 意为根据防火墙伪装Referer头,如:“Referer: XXXXXXX”。
server_names     # 为一个或多个服务器的列表,0.5.33版本以后可以在名称中使用“*”通配符。

server_names     # 就是指定哪个来源访问你的网站可以这样配置如下:

valid_referers none blocked  *.youdomain.com youdomain.com server_names ~\.baidu\.;

以上所有来至youdomain.com 域名中baidu的站点都可以访问到当前站点的图片,如果来源域名不在这个列表中,
那么$invalid_referer等于1,在if语句中返回一个404给用户.

## 参数配置如下:
location ~* ^.+\.(jpg|gif|png|swf|flv|wma|wmv|asf|mp3|mmf|zip|rar)$ {
    valid_referers none blocked  *.youdomain.com youdomain.com;
    if ($invalid_referer) {
        # rewrite ^/ http://www.youdomain.com/404.jpg;
        return 404;
        break;
     }
     access_log off;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值