通过Nginx实现图片防盗链的方法
原创性质的图文站,经常会遇到这样的问题:盗链。现在的采集软件特别多,可以通过制定一系列的规则,将别人网站上的资源下载到本地或同步到自己的网站上。
文字型的复制十分简单,图片型的需要额外存储,所以很多采集站长会选择盗链的形式。何为盗链?简单来说,就是将你网站上图片的链接放到别人的网站上,这样在访问那个人的网站时,实际上在调用你网站的图片,不仅使用你的图片,还用你的流量带宽。
这种事情叔可忍婶都忍不了,今天来教大家如何通过Nginx实现图片防盗链。
首先在nginx的配置文件中找到如下内容:
第三行是缓存过期时间,就是别人在访问你的网站时,会将这些文件下载到本地缓存中,再次访问时直接读缓存中的内容,加快网站打开速度。这些缓存资源保存30天,超过30天会删除本地的缓存,然后重新下载。
第四行为是否记录访问日志,off不记录。当别人访问你的静态资源时,不做记录,减少访问日志生成。
我们需要将上面的内容改为:
第三行调用第二行的值,如果不是的话,执行第四行的操作;
第四行为返回图片,当遇到盗链时,将此图片返回。红色字体处需替换,同时需要准备以绿色字体命名的图片一张,放在网站根目录中。
文字型的复制十分简单,图片型的需要额外存储,所以很多采集站长会选择盗链的形式。何为盗链?简单来说,就是将你网站上图片的链接放到别人的网站上,这样在访问那个人的网站时,实际上在调用你网站的图片,不仅使用你的图片,还用你的流量带宽。
这种事情叔可忍婶都忍不了,今天来教大家如何通过Nginx实现图片防盗链。
首先在nginx的配置文件中找到如下内容:
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$第一行是文件类型,访问这些文件时按照下面的设置。
{
expires 30d;
access_log off;
}
第三行是缓存过期时间,就是别人在访问你的网站时,会将这些文件下载到本地缓存中,再次访问时直接读缓存中的内容,加快网站打开速度。这些缓存资源保存30天,超过30天会删除本地的缓存,然后重新下载。
第四行为是否记录访问日志,off不记录。当别人访问你的静态资源时,不做记录,减少访问日志生成。
我们需要将上面的内容改为:
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {第二行为判断访问网址,是否通过这个地址访问图片,同时包含谷歌、百度形式访问。红色字体处需替换;
valid_referers none blocked *.birdteam.net server_names ~\.google\. ~\.baidu\.;
if ($invalid_referer) {
rewrite ^/ http:///403.jpg;
}
expires 30d;
access_log off;
}
第三行调用第二行的值,如果不是的话,执行第四行的操作;
第四行为返回图片,当遇到盗链时,将此图片返回。红色字体处需替换,同时需要准备以绿色字体命名的图片一张,放在网站根目录中。