English
 电子信箱
 加入收藏

  威盾防火墙 >> 新闻中心 >> 威盾新闻 >> 纠正网上 .htaccess 图片防盗链方法的错误

 

纠正网上 .htaccess 图片防盗链方法的错误

威盾防火墙 2014-11-11

 

也许并不是错误,只是服务器配置不同造成的个案,仅当做参考吧。

 

从网上看来的方法说在.htaccess文件中加入如下代码可以防止其他网站盗链图片:

 

RewriteEngine on
RewriteCond %{HTTP_REFERER} !^[url]http://blog.51cto.com[/url]/.*$ [NC]
RewriteCond %{HTTP_REFERER} !^[url]http://blog.51cto.com[/url]$ [NC]
RewriteCond %{HTTP_REFERER} !^[url]http://www.51cto.com[/url]/.*$ [NC]
RewriteCond %{HTTP_REFERER} !^[url]http://www.51cto.com[/url]$ [NC]
RewriteRule .*\.(jpg|gif|png)$ /missing.jpg [R,NC]

 

对其方法稍微改进一下(由于博客三级域名的原因)。

RewriteCond %{HTTP_REFERER} !^http://(.)+\.51cto\.com [NC]
RewriteRule .*\.(jpg|gif|png|bmp)$ images/err.gif [R,NC]

 

试用后,发现图片并没有想想像中的转到指定图片,而是红叉。在新窗口中打开图片后发现图片也被认为是盗链,但是很长时间打不开。这时监看服务器负载情况,CPU占用变高,其中一个httpd进程占了大量系统资源。把新窗口关掉,服务器恢复正常。

 

分析了一下问题原因,RewriteRule .*\.(jpg|gif|png|bmp)$ images/err.gif [R,NC]这句,将所有的图片文件重定向到images/err.gif文件,可是images/err.gif仍然是错误的,他还会再次重定向,反复重定向造成一个死循环。。。后来修改RewriteRule .*\.(jpg|gif|png|bmp)$ images/err.gif [R,NC]中的[R,NC]为[L,NC]。服务器负载正常,盗链的页面上可以显示出错误提示图片,而非前面的红叉。


相关内容: 最新内容:
图文解析IIS下Rewrite组件防盗链[2014-11-11]
IIS 防盗链 软件[2014-11-11]
怎么解决网站防盗链[2014-11-10]
网站防盗链是什么?[2014-11-10]
我来教你玩转iis防盗链 MYIIS-VIF超级防盗链[2014-11-09]
fastdfs 开启 token 防盗链,以及验证失败原因[2014-11-07]
图文解析IIS下Rewrite组件防盗链[2014-11-11]
IIS 防盗链 软件[2014-11-11]
RHEL/CentOS使用yum update更新时不升级内核的方法[2014-11-11]
OpenWRT 路由配置技巧[2014-11-11]
IIS 如何防止代码注入?[2014-11-11]
网络安全基础知识浅析[2014-11-10]