nginx防盗链配置:利用referer指令详解

4 下载量 43 浏览量 更新于2023-05-11 收藏 53KB PDF 举报
"nginx防盗链配置方法利用referer指令" 在网络安全和资源保护方面,防止他人未经许可盗用网站上的资源(如图片、视频等)是非常重要的。Nginx服务器提供了ngx_http_referer_module模块,通过配置referer指令,可以有效地实现防盗链功能。下面我们将详细介绍如何利用Nginx的referer指令来实现防盗链配置。 首先,了解referer字段。在HTTP请求头中,referer字段记录了用户的来源页面URL,用于指示用户是从哪个页面点击链接到达当前请求的页面。在防盗链配置中,我们依据这个字段来判断请求是否合法。 下面是一个具体的防盗链配置示例,针对图片资源(如.gif、.jpg、.png、.webp): ```nginx location ~* \.(gif|jpg|png|webp)$ { valid_referers none blocked domain.com *.domain.com server_names ~\.google\. ~\.baidu\.; if ($invalid_referer) { return 403; # 或者 rewrite ^ /http://www.domain.com/403.jpg; } root /opt/www/image; } ``` 这段配置的含义如下: 1. `location ~* \.(gif|jpg|png|webp)$`:定义匹配图片文件的location块,使用正则表达式匹配以.gif、.jpg、.png或.webp结尾的URL。 2. `valid_referers none blocked domain.com *.domain.com server_names ~\.google\. ~\.baidu\.;`:设置合法的referer列表。这里的`none`表示允许无referer的请求(例如直接在浏览器地址栏输入图片URL的情况),`blocked`表示阻止所有其他非法请求,`domain.com`和`*.domain.com`允许来自domain.com及其子域名的请求,`~\.google\.`和`~\.baidu\.`则允许来自以.google和.baidu结尾的域名的请求。 3. `if ($invalid_referer) { return 403; }`:如果请求的referer不在合法列表中,`$invalid_referer`变量将被设置为1,这将导致Nginx返回403 Forbidden状态码,拒绝提供图片资源。 4. `# rewrite ^ /http://www.domain.com/403.jpg;`:这行代码是可选的,如果启用,当请求被拒绝时,浏览器会显示指定的403错误页面(这里是403.jpg)。 通过以上配置,只有来自domain.com、其子域名以及google和baidu结尾的站点的请求才能正常访问这些图片资源,其他来源的请求都将被阻止。我们可以通过curl命令模拟请求并查看响应状态码来测试配置的有效性,如示例中所示。 利用Nginx的referer指令进行防盗链配置是一种简单而有效的策略,能够保护网站资源不被非法盗用。需要注意的是,防盗链配置虽然可以提供一定的保护,但并不能完全防止所有的盗链行为,因为有些恶意用户可能会篡改或伪造referer字段。因此,结合其他安全措施(如使用HTTPS、设置访问令牌等)可以进一步增强资源保护。