【亲测】nginx设置图片防盗链的实现方法

草蛋 2023-01-06 11:38:04 1

大家好,对【亲测】nginx设置图片防盗链的实现方法感兴趣的小伙伴,下面一起跟随草蛋来看看【亲测】nginx设置图片防盗链的实现方法的介绍吧。

因为nginx不支持.htaccess,所以在防盗链上比较麻烦。上网搜了一下,代码很容易搜到,甚至lnmp一键安装包的作者Licess都给出了这样一段防盗链代码,但是还是有很多人叫着方法无效,这是为什么呢?

Licess给出的代码如下:

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
valid_referers none blocked caocaoz.com *.caocaoz.com *.youdao.com *.zhuaxia.com *.xianguo.com *.google.cn *.google.com *.google.com.tw *.google.com.sg *.google.com.hk *.bloglines.com image.soso.com cn.bing.com image.baidu.com *.feedburner.com *.feedsky.com;
if ($invalid_referer) {
rewrite ^/ http://www.caocaoz.com/mypoco/myphoto/20100506/20/124649620100506204112026.jpg;
#return 404;
}
}

把这段代码加入到 /usr/local/nginx/conf/nginx.conf server 段里,然后执行如下命令重启lnmp:

lnmp restart

很多人在测试了这个方法以后,发现没有效果,这是为什么呢?原因在于上面这段代码跟另一段代码产生了冲突。同样是修改 /usr/local/nginx/conf/nginx.conf 文件,把其中的下面这段代码删除:

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
}

删除以后,再次重启lnmp,你会发现,防盗链设置已经生效了。

也可以将两者组合,形成一段新的代码:

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
valid_referers none blocked *.caocaoz.com *.youdao.com *.zhuaxia.com *.xianguo.com *.google.cn *.google.com *.google.com.tw *.google.com.sg *.google.com.hk *.bloglines.com image.soso.com cn.bing.com image.baidu.com *.feedburner.com *.feedsky.com;
if ($invalid_referer) {
rewrite ^/ http://www.caocaoz.com/mypoco/myphoto/20100506/20/124649620100506204112026.jpg;
#return 404;
}
}

重启lnmp,你会发现,防盗链设置仍然有效。

你可能喜欢的内容:

防盗链