Nginx的防盗链配置

aries 发表于 2012-08-31 1196 次浏览 标签 : lnmp防盗链

Apache换成Nginx后,记录一些Apache转换过程中的小细节,留下备忘。

Nginx的防盗链

一般的防盗链如下:

location ~* .(gif¦jpg¦png¦swf¦flv)$ {
valid_referers none blocked www.iw3c.com www.xiaomizhou.net;
if ($invalid_referer) {
rewrite ^/ http://www.iw3c.com/403.html;
#return 404;
}
}

第一行:gif|jpg|png|swf|flv

表示对gif、jpg、png、swf、flv后缀的文件实行防盗链

第二行:www.iw3c.com www.xiaomizhou.net

表示对www.iw3c.com www.xiaomizhou.net这2个来路进行判断

if{}里面内容的意思是,如果来路不是指定来路就跳转到错误页面,当然直接返回404也是可以的。

NginxHttpAccessKeyModule实现防盗链

如果不怕麻烦,有条件实现的话,推荐使用NginxHttpAccessKeyModule这个东西。

他的运行方式是:如我的download 目录下有一个 file.zip 的文件。对应的URI 是http://www.iw3c.com/download/file.zip

使用ngx_http_accesskey_module 模块后http://www.iw3c.com/download/file.zip?key=09093abeac094. 只有给定的key值正确了,才能够下载download目录下的file.zip。而且 key 值是根据用户的IP有关的,这样就可以避免被盗链了。

据说NginxHttpAccessKeyModule现在连迅雷都可以防了,可以尝试一下。

0条评论

如需评论,请填写表单。
换一个

记住我的信息