`
东明伊人
  • 浏览: 11310 次
  • 性别: Icon_minigender_2
  • 来自: 长沙
最近访客 更多访客>>
文章分类
社区版块
存档分类

IIS服务器的网站防盗链的解决方案

阅读更多

盗链是指服务提供商自己不提供服务的内容,通过技术手段绕过其它有利益的最终用户界面(如广告),直接在自己的网站上向最终用户提供其它服务提供商的服务内容,骗取最终用户的浏览和点击率。受益者不提供资源或提供很少的资源,而真正的服务提供商却得不到任何的收益。

针对图片的防盗链方法:httpd.ini 文件的任意处增加下列代码(IIS 的 httpd.ini 和 Apache 的 .htaccess  文件原理是一样的!)

RewriteCond Host: (.+)
#排除以下网站
RewriteCond Referer: (?!http://(?:173it\.cn|(.*)\.173it\.cn|72km\.cn|(.*)\.php100\.com|baidu\.com|(.*)\.baidu\.com|google\.com|(.*).\google.com)).*
#其他网站的图片、软件下载请求都转向到 block.png 中
RewriteRule (.*\.(?:jpg|jpeg|gif|png|bmp|rar|zip|exe)) /block.png [I,O,N]

针对下载的防盗链方法: download.php 文件相当于一个“守城兵”,负责保护数据、传递数据。它会判断 $_SERVER['HTTP_REFERER'] 与本站域名是否有匹配,如果否,则说明该下载请求来自他站,此时拒绝下载,显示“请不要盗链本站资源”。如果是本站的下载请求,则调用下载类----读取文件并输出下载。($_SERVER['HTTP_REFERER']  这个服务器变量的意思是:获取当前链接的上一个连接的来源地址,即链接到当前页面的前一页面的 URL 地址)

主要有两个文件:download.php 、Download.class.php    下载

现在开始看代码:

假设我提供下载的地址是:http://www.173it.cn/download.php?fn=文件名.rar 

当此链接被点击后,download.php 开始工作——过滤非本站的下载请求,如请求通过,则返回数据给用户。

download.php

<?php
include_once 'Download.class.php';
$referer = $_SERVER['HTTP_REFERER'];
$host    = 'php95.com';
if(!strpos($referer,$host)){
    echo '请不要盗链本站资源!';
}else{
 // 压缩文件自由放置,在这里加上路径就可以了。比如  $fn = '\a\b\c\\'.$_GET[fn]; 
 $fn = $_GET[fn];
 $dl=new Download();
 $dl->_dl_($fn);
}
?>

Download.class.php

/**
* 下载类
* 示例: $dl = new Download(); $dl->_dl_('a.rar');
**/
 class Download{
  var $cache_size=1024;
  function Download(){}
  //文件的相对路径
  function _dl_($path)
  {
   $full_path=getcwd().$path;
   //echo $full_path;
   if(!file_exists($full_path)){
    echo "File Not Find.";
    exit;
   }else{
    $handle=fopen($full_path,"rb");
    Header("Content-type:".$this->getmimetype($full_path));
    Header("Accept-Ranges:bytes");
    Header("Accept-Length:".filesize($full_path));
    $infos=pathinfo($full_path);
    Header("Content-Disposition:attachment;filename=".$infos["basename"]);
    while(!feof($handle)){
     echo fread($handle,$this->cache_size);
    }
    fclose($handle);
    exit;   
   }
  }
  function getmimetype($path){
   $mimeArray=array();
   $mimeArray["zip"]="application/zip";
   $mimeArray["wav"]="audio/x-wav";
   $mimeArray["xml"]="application/xml";
   $mimeArray["txt"]="text/plain";
   $mimeArray["tar"]="application/x-tar";
   $mimeArray["swf"]="application/x-shockwave-flash";
   $mimeArray["rm"]="application/vnd.rn-realmedia";
   $mimeArray["pdf"]="application/pdf";
   $mimeArray["mp3"]="audio/x-mpeg";
   $mimeArray["mid"]="audio/x-midi";
   $mimeArray["js"]="text/javascript";
   $mimeArray["jad"]="text/vnd.sun.j2me.app-descriptor";
   $mimeArray["gz"]="application/x-gzip";
   $mimeArray["gtar"]="application/x-gtar";
   $mimeArray["exe"]="application/octet-stream";
   $mimeArray["doc"]="application/msword";
   $mimeArray["rar"]="application/octet-stream";
  
   $infos=pathinfo($path);
   return $mimeArray[$infos["extension"]]; 
  }
 }//end class Download

?>

对外提供下载地址的格式是:http://本站域名/download.php?fn=文件名.rar

分享到:
评论

相关推荐

    IIS图片防盗链和下载的解决方案

    最近服务器需要防图片别盗链,所以找了很多代码,下面给出具体配置代码

    目前最好的IIS防火墙-威盾IIS防火墙

    具备禁用代理访问、高级盗链保护、URL安全过滤、IP地址阻塞等多种安全防护功能,可为基于IIS服务器建设的网站系统提供全方位、一体化、高效能的整体安全解决方案。 IISWALL采用最新的VC++.NET开发编制,基于最...

    威盾IIS防火墙 v4.8 Build 2010.10.10.zip

    基于最高效的ISAPI Filter技术实现,具有速度快、效率高、应用防护透明化等特点,在IIS内核中实现真正意义上的全方位安全防护,是迄今为止解决IIS安全问题最完整的安全解决方案之一,已在黑客基地等日百万访问量的...

    威盾V3.71 Build 90403.rar

    具备防黑客、防盗链、防下载等多种安全防护和带宽管理功能的应用级防火墙,可为基于IIS服务器建设的网站系统提供全方位、一体化、高效能的整体安全解决方案。 威盾防火墙采用最新的VC .NET开发编制,基于最高效的...

    ASP.NET Night Words

    4.3 创建基于解决方案的asp.net 4.3 应用程序 35 4.4 asp.net内置文件夹介绍 36 4.5 xml注释 37 4.6 任务管理器 38 4.7 配置外部工具 39 4.8 代码段管理器 40 4.9 发布asp.net网站 44 4.10 总结 45 第5章 ...

    史上最好传智播客就业班.net培训教程60G 不下会后悔

    代码生成、网页静态化、基于JQuery的Web2.0页面开发、AJAX、SEO、网站调优、采集器、RSS/XML、网站防黑(防XSS攻击、防注入漏洞攻击、防CC攻击、防挂马、防盗链、敏感词过滤、广告帖智能过滤)、IIS管理与调优、流量...

    亮剑.NET深入体验与实战精要2

    3.4.7 在URL中传递中文的解决方案 152 3.4.8 增强用户体验的一些技巧 153 3.4.9 XHTML与HTML的区别 156 3.5 打造自己的页面基类PageBase 161 本章常见技术面试题 164 常见面试技巧之如何做好自我介绍 164 本章小结 ...

    亮剑.NET深入体验与实战精要3

    3.4.7 在URL中传递中文的解决方案 152 3.4.8 增强用户体验的一些技巧 153 3.4.9 XHTML与HTML的区别 156 3.5 打造自己的页面基类PageBase 161 本章常见技术面试题 164 常见面试技巧之如何做好自我介绍 164 本章小结 ...

    ASP.NET3.5典型模块开发源代码

    12.3 ASP.NET 3.5中防盗链的解决方案 142 12.3.1 设计处理图片的HttpHandler处理程序 143 12.3.2 在应用配置中注册HttpHandler 144 12.3.3 在IIS中配置图片的特殊处理程序 145 12.3.4 测试处理程序的执行...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part1

    每个实例都经作者精心筛选,具有很强的实用性,其中一些实例是开发人员难于寻觅的解决方案。   本书适合PHP的初学者,如高校学生、求职人员作为练习、速查、学习使用,也适合PHP程序员参考、查阅。 目 录 目录:...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part2

    每个实例都经作者精心筛选,具有很强的实用性,其中一些实例是开发人员难于寻觅的解决方案。   本书适合PHP的初学者,如高校学生、求职人员作为练习、速查、学习使用,也适合PHP程序员参考、查阅。 目 录 目录:...

Global site tag (gtag.js) - Google Analytics