A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 黑马——兰雷明 黑马帝   /  2012-6-10 04:55  /  1923 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

除了根据UrlReferrer实现盗链外,还有哪种方法啊? 这种实现的防盗链可以通过改请求报文破解防盗链,有没有一种从根本上解决问题的方法啊?麻烦详细说下啊

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

2 个回复

倒序浏览
没人么。。。
回复 使用道具 举报
举一个例子,本例子使用httpHandle来实现,对图片文件的请求做专门的处理来实现图片防盗链功能
1,创建一个类,继承自IHttpHandler;
2,编译成DLL,csc /t:library CustomHandler.cs;
3,添加编译好的DLL引用到当前站点的bin文件夹下;
4,在Web.Config 中注册这个Handler.
代码1如下:
using System;
using System.Web;
namespace CustomHandler
{
        publicclass JpgHandler : IHttpHandler
         {
        publicvoid ProcessRequest(HttpContext context)
          {
           // 获取文件服务器端物理路径
          string FileName = context.Server.MapPath(context.Request.FilePath);
          // 如果UrlReferrer为空,则显示一张默认的禁止盗链的图片
         if (context.Request.UrlReferrer.Host == null)
         {
                 context.Response.ContentType = "image/JPEG";
                 context.Response.WriteFile("/error.jpg");
          }
           else
          {
              // 如果 UrlReferrer中不包含自己站点主机域名,则显示一张默认的禁止盗链的图片
              if (context.Request.UrlReferrer.Host.IndexOf("yourdomain.com") > 0){
             context.Response.ContentType = "image/JPEG";
             context.Response.WriteFile(FileName);
           }
          else
           {
               context.Response.ContentType = "image/JPEG";
               context.Response.WriteFile("/error.jpg");
              }
        }
   }
     publicbool IsReusable
    {
       get{ returntrue; }
     }
   }
}


代码4如下:
<system.web>
<httpHandlers>
<add path="*.jpg,*.jpeg,*.gif,*.png,*.bmp" verb="*" type="CustomHandler.JpgHandler,CustomHandler" />
</httpHandlers>
</system.web>
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马