IIS防盗链 ISAPI Rewrite图片防盗链规则写法

admin3年前网站建设33

通过G.CN和B.CN搜索后得出了几种不同的方案,例如网站程序的URL伪装法、服务器端的收费插件法和ISAPI-REWRITE的规则过滤法等,考虑自身网站结构和钱包的困难问题,最终选择了后者,即现在流行用来做伪静态的ISAPI Rewrite书写规则来实现我的防盗链“梦想”。

为什么说是梦想呢?首先表示惋惜,懒人我搜来了一大票经过无数次转载而来的文章,把现呈的代码应用后发现要么根本不起作用,要么就是效果达不到我想要的,几经周折后终于把这原本认为可以轻易借鉴照搬的防盗链给完成了,恨那些只会转载和伪原创的站长们,自己也不试试就拿来填充,害了多少人浪费了大把的时间。

经过恶补正则表达式相关教程并对前辈们留下的规则进行修改后,以下ISAPI Rewrite已经在我的服务器上正常运作。

经测试四种情况正常,即站内链接正常,白名单里的链接正常,盗链者链接屏蔽,搜索引擎链接正常。
详细如下;
一、完全屏蔽所有盗链来源的写法(如已有其它规则,则置于已有规则的上面)
代码:

复制代码 代码如下:


RewriteCond Host: (.+)
RewriteCond Referer: (?!\1.*).*
RewriteRule .*\.(?:gif|jpg|jpeg|png|bmp) /block.gif [I,O,N]



老板,来个小解:
第一行通过RewriteCond的HOST定义其下的规则所适用的请求主机范围。
第二行通过RewriteCond的Referer定义规则适用的请求来源地址,我们都知道任何通过互联网方式访问网站都会留下Referer的痕迹,就好像我们在IIS日志里看到的一样。这里的(?!\1.*).*意思就是判断所有通过http协义发来的请求,都要应用规则。
第三行通过RewriteRule定义防盗链文件的后缀,这里仅是图片后缀,需要的可以添加mp3,rar等其它所有后缀。后面的/block.gif表示如果遇上这些后缀的文件被盗链后的转向,这里转向/根目录的block.gif,可以是HTML等任何文件。如果只想某个文件夹下面的文件不被盗链,只需要加上路径就可以。例如不想images和pic目录下的文件被盗,但其它可以。就要改写成:
RewriteRule (/images/|/pic/).*\.(?:gif|jpg|jpeg|png|bmp) /block.gif [I,O,N]
这种情况主要是有些站长在别人友情链接里的图片地址是在自己这的。
最后面的[I,O,N],I表示不区分大小写,O表示对URL进行标准化,可能是用来处理Unicode编码的地址(例如包含中文的URL)以及QueryString的内容,N表示重新从站点请求文件而不是从本地缓存读取文件,目的是防止当用户访问了盗你链的网站后,再回到你的网站也出现盗链提示。
提示,由于此规则是通过Referer来获取带有字样的地址进行过滤,因此它无法防范其它协议的盗链,比如迅雷下载。但通过任何浏览器直接访问,只要是HTTP协义的,通杀。
以上关于RewriteCond和RewriteRule的作用仅是本人的土法理解,欢迎在这方面有专业研究的朋友在评论中指正,以免误导,另外如果遇到isapi-rewrite版本问题,只要保证后面的正则式写法正确就行。
二、排除性防盗链写法
代码:

复制代码 代码如下:


RewriteCond Host: (.+)
RewriteCond Referer: (?!\1.*).*
RewriteCond Referer: (?!(.*)(\.baidu\|\.google\|\.google\|\.g\|\.gougou\|\.soso\|\.sogou\|\.youdao\|\.bing\|\.yahoo\|\.yahoo\|\.eojoo\)).*
RewriteRule .*\.(?:gif|jpg|jpeg|png|bmp) /block.gif [I,O,N]


老板,来个小解:
第一行同上
第二行同上
第三行通过正则表达式对第二行中的请求协义地址进行过滤,这里按上面的写法,过滤了所有流行的搜索引擎,当然也包括你自己的站,或是你同台服务器其它的站。每个不同的域名写法是\.baidu\,多个有|号相隔。如果是IP则这样写100\.100\.100\.100
第四行同上
这样说明应该不难理解吧,直接拿去用,按着原有格式改。
规则中出现的正则表达式符号小解:
. 表示匹配除换行符以外的任意字符
+ 表示前面的字符可以出现一到任意多次
* 表示前面的字符可以出现零到任意多次
() 表示一个表达组,可以拿它和加减乘除法一起理解
?! 表示断言这个符号后面的字符如果出现则不再进行接下去的匹配
\ 表示转义符号,比如网址中的.是规则内置的运算符号,要把它通过\转义成字符。
| 表示或者,用于连接多种可能
通过以上这“乱七八糟”的符号,竟然组成了如此强大的规则,感叹!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

seoer,您走火入魔了吗?

 作为一个网站站长,请问您一天用几次站长工具?一天查多少次友情链接,一天点击自己的网站多少次?我虽然做SEO的时间不长,但是我的第一份工作就是SEO,当初为了让自己的关键词上去,站长工具每天不知道查询...

一个公司网站制作需从什么方面考虑

网站建设本就以客户服务需求、网络市场营销为主导,再结合行业、企业具体实际情况,根据在不同发展阶段的战略管理目标及战术,而制定出一个阶段性的网站建设方案。那么,在公司网站制作中,企业需要从哪些方面考虑?...

网站制作增加流量的具体方法

1、网站优惠活动 每当看到最新优惠活动时,用户就忍不住停下来浏览和观看。同样,网站上的优惠活动也会吸引用户的注意。特别是,一些经常关注你的用户会毫不犹豫地光顾你的优惠活动。 2、网...

在其他接入商处备案过,现在要换接入商还能备案吗?

如果您在备案过程中遭遇之前做过网站备案,但是由于时间久也找不到之前备案企业了或者别的因素需要变换备案点的,现在能够不用那么麻烦去转入之前备案再提升备案了,只需在新的备案平台注册,例如我们的西部数码备案...

浅析建设电脑网站与手机端网站有三种不同之处

想要建设开发一个优质的手机网站,那么首先就要对现今社会行业中手机网站的发展有所了解,并且要有高质量的建站技巧,这都是必不可少的因素。而在建设手机网站的过程中,许多人会好奇,不同平台手机和电脑在建立网站...

网站新闻栏目如何制作才是优质网页

什么样的网页算优质网页呢?以谁为标准呢?网页是给用户看的,自然应该以用户审美为标准,但用户审美千差万别,很难有统一标准,今天我们主要讨论新闻栏目页面,因为新闻栏目需要持续更新,往往也是收录最多的页面。...