菜单

防盗链的实现

2018年12月31日 - 注册免费送38元体验金

正文转载:http://www.cnblogs.com/eflylab/archive/2008/06/16/1223373.html

突发性我们需要制止其他网站间接引用大家系统中的图片,或下载文件链接。需要禁止盗链!在ASP.NET中得以方便的实现该效用!
做一个简短的盗链图片的以身作则,如下。新建立一个WebApplcation。新成立一个images文件夹,里面二张jpg图片,一张logo.jpg正常图片,一张用于指示地下盗链的图形Error.jpg图片。
页面default.aspx页面很简短。就一个图片如下

图片 1<form id=”form1″ runat=”server”>
图片 2    <div>
图片 3    <img src=”images/logo.jpg” />
图片 4    </div>
图片 5    </form>

此地运用HttpHandler来处理盗链问题
新确立一个
一般处理程序 Handler1.ashx.代码及注释如下

图片 6public void ProcessRequest(HttpContext context)
图片 7        {
图片 8            //判断是否是本地网站引述图片,假使是则赶回正确的图形
图片 9            if (context.Request.UrlReferrer.Host == “localhost”)
图片 10            {
图片 11                //设置客户端缓冲时间过期时间为0,即立刻过期
图片 12                context.Response.Expires = 0;
图片 13                //清空服务器端为此会话开启的输出缓存
图片 14                context.Response.Clear();
图片 15                //设置输出文件类型
图片 16                context.Response.ContentType = “image/jpg”;
图片 17                //将请求文件写入到输出缓存中
图片 18                context.Response.WriteFile(context.Request.PhysicalPath);
图片 19                //将出口缓存中的信息传送到客户端
图片 20                context.Response.End();
图片 21            }
图片 22            //假若不是地点引用,则是盗链本站图片
图片 23            else
图片 24            {
图片 25                //设置客户端缓冲时间过期时间为0,即即刻过期
图片 26                context.Response.Expires = 0;
图片 27                //清空服务器端为此会话开启的输出缓存
图片 28                context.Response.Clear();
图片 29                //设置输出文件类型
图片 30                context.Response.ContentType = “image/jpg”;
图片 31                //将请求文件写入到输出缓存中
图片 32                context.Response.WriteFile(context.Request.PhysicalApplicationPath + “images/error.jpg”);
图片 33                //将出口缓存中的消息传递到客户端
图片 34                context.Response.End();
图片 35            }
图片 36        }
图片 37        //该属性表示HTTP请求是否足以应用当前处理
图片 38        public bool IsReusable
图片 39        {
图片 40            get
图片 41            {
图片 42                return true;
图片 43            }
图片 44        }

该公文用于接管HTTP请求JPG格式的图形。尽管是从主机localhost访问的,则允许。否则展现错误的图样!
到此处该公文还一直不效益,需要在Web.config文件举行配备HttpHandler节点
如下

图片 45<httpHandlers>
图片 46        <add verb=”*” path=”.jpg” type=”MyNamespace.Handler,MyNamespace”/>
图片 47      </httpHandlers>

来测试下
启动
图片 48
图片正常突显。如若将访问地址改为 http://127.0.0.1:2136/Default.aspx 效果如下
图片 49 

但此刻将该品种揭发到IIS中,运行
图片 50
从未出现希望效果,这是因为通过IIS请求
并不曾将.JPG的格式使用.NET引擎举行分解,而是如静态页面HTML一样直接再次来到给了用户,这时我们盼望用户请求.JPG时也能像.ASPX一样即可解决这一个问题,打开IIS。选用该网站
右键属性
图片 51
点击配置
图片 52
点击添加
图片 53
添加.jpg后缀的伸手。交给aspnet_isapi.dll处理,这样大家协调写的相似处理程序
Handler1.ashx就有效用了,
兴许多心的心上人会问,咱们不是在web.config中写了如此一个配备的吧?为啥一向不功能吧。这是由于IIS对.jpg后缀的乞请直接就加载图片重临了,这里并不会采纳aspnet_isapi.dll处理,所以也就愈加到达不了Handler1.ashx这一步,当我们在IIS中配置后,即可实现!

基于同样的法则也得以兑现
下载文件的防盗链~原理雷同~ 

展开一下,使用该法还可以够缓解站内信息资讯被人采用蜘蛛程序抓取的题材!

唯独此法并非没有缺陷,紧要的就是会回落系统的性能!这些要看个人权衡了!

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图