西数超哥博客
运维经验教程分享

通过Nginx实现图片防盗链

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

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

这种事情叔可忍婶都忍不了,今天来教大家如何通过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://birdteam.net/403.jpg;
  5.         }
  6.         expires      30d;
  7.         access_log off;
  8. }

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

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

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

www.ysidc.top 西数超哥博客,数据库,西数超哥,虚拟主机,域名注册,域名,云服务器,云主机,云建站,ysidc.top

赞(0)
声明:本站发布的内容(图片、视频和文字)以原创、转载和分享网络内容为主,若涉及侵权请及时告知,将会在第一时间删除。本站原创内容未经允许不得转载:西数超哥博客 » 通过Nginx实现图片防盗链