教你如何通过Nginx实现图片防盗链

  • A+
所属分类:技术教程

原创性质的图文站,经常会遇到这样的问题:盗链。现在的采集软件特别多,可以通过制定一系列的规则,将别人网站上的资源下载到本地或同步到自己的网站上。

 

文字型的复制十分简单,图片型的需要额外存储,所以很多采集站长会选择盗链的形式。何为盗链?简单来说,就是将你网站上图片的链接放到别人的网站上,这样在访问那个人的网站时,实际上在调用你网站的图片,不仅使用你的图片,还用你的流量带宽。

这种事情叔可忍婶都忍不了,今天来教大家如何通过Nginx实现图片防盗链。

首先在nginx的配置文件中找到如下内容:


  1. location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$  
  2.     {  
  3.         expires      30d;  
  4.         access_log off;  
  5.     }  

第一行是文件类型,访问这些文件时按照下面的设置。

 

第三行是缓存过期时间,就是别人在访问你的网站时,会将这些文件下载到本地缓存中,再次访问时直接读缓存中的内容,加快网站打开速度。这些缓存资源保存30天,超过30天会删除本地的缓存,然后重新下载。

 

第四行为是否记录访问日志,off不记录。当别人访问你的静态资源时,不做记录,减少访问日志生成。

我们需要将上面的内容改为:

  1. location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {  
  2.         valid_referers none blocked *.birdteam.net server_names ~\.google\. ~\.baidu\.;  
  3.         if ($invalid_referer) {  
  4.                 rewrite ^/ http:///403.jpg;  
  5.         }  
  6.         expires      30d;  
  7.         access_log off;  
  8. }  

第二行为判断访问网址,是否通过这个地址访问图片,同时包含谷歌、百度形式访问。红色字体处需替换;

 

第三行调用第二行的值,如果不是的话,执行第四行的操作;

 

第四行为返回图片,当遇到盗链时,将此图片返回。红色字体处需替换,同时需要准备以绿色字体命名的图片一张,放在网站根目录中。

黄 先森

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: