一、全站的防盗链方法



在sudo vi /etc/nginx/conf.d/default.conf(nginx安装方式不一样,配置文件位置也不一样) 


文件要添加防盗链的server段里添加下面的代码:


location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { 

 valid_referers none blocked 192.168.10.111;#改成自己的 

 if ($invalid_referer) { 

 rewrite ^/ http://192.168.10.111/403.html; 

 #return 403; 

   } 

 }



保存重启nginx 即可


service nginx restart




测试方法:自己在非192.168.10.111服务器上新建个html,<img src="http://192.168.10.111/test.jpg"> 查看效果




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


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


第二行:表示对www.5icool.org这2个来路进行判断


if{}里面内容的意思是,如果来路不是指定来路就跳转到http://192.168.10.111/403.html页面,当然直接返回403也是可以的。


请确保server段中只有一个location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$,否则可能导致代码无效,如有这个代码段请合并或删除。


切记:如果要跳转到图片,记得替换的图片地址要使用没有防盗链的网站图片,否则由于替换的图片其实也处于防盗链情况下,会造成仍旧无法显示设置的图片。





二、针对图片目录防止盗链



location /images/ { 

   alias /data/images/; 

   valid_referers none blocked server_names 192.168.10.111;#改成自己的 

   if ($invalid_referer) {return 403;} 

 }