PHP文件与图片防盗链处理类

悲剧,刚提交的既然服务器挂了没成功,又得重写....

这几天在写一个PHP防盗链外部资源下载处理函数,昨天晚上刚完成编写,中间遇到了些问题,这里就不详述了;

以下是自写的简单的PHP防盗链处理类(重新整理编写成类文件,以便后期改进);

 代码如下 复制代码

<?php 

002 /** 

003  * 

004  * 防盗链外部资源下载处理类 

005  *  

006  * @author 清风 <xrcc_bk@126.com> 

007  * @link   http://blog.emtalk.net 

008  *  

009  */

010 class BurglarDow{ 

011     /** 

012      * 初始许可下载状态 

013      * @var    allow 

014      * @access private 

015      */

016     private $allow      =  false; 

017     /** 

018      * 初始下载地址 

019      * @var    dowUrl 

020      * @access private 

021      */

022     private $dowUrl     =  null; 

023     /** 

024      * 初始来路域名 

025      * @var    RemoteUrl 

026      * @access private 

027      */

028     private $RemoteUrl  =  null; 

029     /** 

030      * 初始许可资源取用域名列表 

031      * @var    allowUrl 

032      * @access private 

033      */

034     private $allowUrl   =  array(); 

035     /** 

036      * 初始转跳地址 

037      * @var    Location 

038      * @access private 

039      */

040     private $Location   =  null; 

041   

042     public function __construct($dowUrl,$Location,array $allowUrl){ 

043         // 初始下载地址 

044         $this->dowUrl   = $dowUrl; 

045         // 初始许可资源取用域名列表 

046         $this->allowUrl = $allowUrl; 

047         // 初始转跳地址 

048         $this->Location = $Location; 

049   

050         $this->RemoteUrl = @parse_url($_SERVER['HTTP_REFERER']);                                                      // 获取来路域名 

051         if(!is_array($this->RemoteUrl)) 

052             header("HTTP/1.1 301 Moved Permanently"); 

053             header("Location: ".$this->Location); 

054   

055         if(isset($this->RemoteUrl['host'])){ 

056             if(in_array($this->RemoteUrl['host'],$this->allowUrl)){                                                   // 判断是否来至许可域名 

057                 $this->allow  = true;                                                                                 // 下载许可状态为:真 

058             } 

059         } 

060         unset($this->allowUrl,$this->RemoteUrl);                                                                      // 释放内存变量 

061     } 

062   

063     /** 

064      * 防盗链资源下载 

065      * @access public 

066      * @return mixed 

067      */

068     public function dow(){ 

069         $FileInfo = get_headers($this->dowUrl,1);                                                                     // 获取远程文件头部信息 

070   

071         if(true === $this->allow){                                                                                    // 判断是否许可下载资源 

072             //判断配置文件是否存在 

073             if(is_file('Config.ini')){ 

074                 $FileCon = parse_ini_file('Config.ini'); 

075             }else{ 

076                 $FileName   =  basename($FileInfo['Content-Location']); 

077                 $FileConStr = "FileName  = {$FileName}rnFileUrl   = {$FileInfo['Content-Location']}rnFileSize   = {$FileInfo['Content-Length']}"; 

078                 $handle = fopen ('Config.ini', "wb");                                                                 // Config.ini文件不存在则创建文件 

079                 if (fwrite ($handle, $FileConStr) == FALSE) {                                                         // 数据写入文件  

080                     echo "File creation failed ...";  

081                 } 

082                 fclose ($handle);                                                                                     // 关闭一个已打开的文件指针 

083                 $FileCon = parse_ini_file('Config.ini'); 

084             } 

085             if(!empty($$this->dowUrl)){ 

086                 $fp = @fopen($$this->dowUrl, "rb");                                                                   // 二进制模式读取文件 

087                 if (!$fp) 

088                      exit("Download a mistake.nn"); 

089   

090                 // 输出远程资源 

091                 header("Content-type:text/html;charset=utf-8"); 

092                 header('Content-Description: File Transfer'); 

093                 header('Content-Type: application/octet-stream'); 

094                 header('Content-Disposition: attachment; filename='.$FileCon['FileName']); 

095                 header("Accept-Ranges: bytes"); 

096                 header('Content-Transfer-Encoding: binary'); 

097                 header('Expires: 0'); 

098                 header('Cache-Control:must-revalidate,post-check=0,pre-check=0'); 

099                 header('Pragma: public'); 

100                 header('Content-Length: '.$FileCon['FileSize']); 

101                 while (!feof($fp)){ 

102                     set_time_limit(0);                                                                                 // 设置文件最长执行时间 

103                     echo fread($fp, 1024);                                                                             // 输出文件 

104                     flush();                                                                                           // 输出缓冲 

105                     ob_flush();                                                                                        // 输出缓冲区中的内容 

106                 } 

107                 fclose($fp); 

108             }else{ 

109                 header("HTTP/1.1 404 Not Found"); 

110             } 

111         }else{ 

112             header("HTTP/1.1 301 Moved Permanently"); 

113             header("Location: ".$this->Location); 

114         } 

115     } 

116 } 

117 // 远程资源地址 

118 $dowUrl = '/qq/QQ5.1/10055/QQ5.1.exe'; 

119 // 转跳地址 

120 $Location = 'http://www.111cn.net'; 

121 // 许可来路域名列表 

122 $allowUrl = array( 

123     'blog.emtalk.net', 

124 ); 

125 $BurglarDow = new BurglarDow($dowUrl,$Location,$allowUrl); 

126 $BurglarDow -> dow();

有何不足之处,还望访友们多指点指点;

时间: 2024-11-11 18:01:20

PHP文件与图片防盗链处理类的相关文章

WordPress图片防盗链的方法总结

通过修改主机根目录下的.htaccess文件防图片盗链 一般的WordPress博客使用的都是Linux主机,所以可以通过FTP进入网站根目录,找到.htaccess文件.在其中加入:  代码如下 复制代码 1.# BEGIN WordPress 2.<IfModule mod_rewrite.c> 3.RewriteEngine On 4.RewriteBase / 5.RewriteRule ^index.php$ - [L] 6.RewriteCond %{REQUEST_FILENAM

Apache实现图片防盗链

Apache实现图片防盗链以及,显示一张"禁止盗链"的图片,我们可以用mod_rewrite 来实现. 假设充许连结图片的主机域名为:www.bianceng.cn 修改httpd.conf SetEnvIfNoCase Referer "^" local_ref=1 <FilesMatch ".(gif|jpg)"> Order Allow,Deny Allow from env=local_ref </FilesMatch&

php实现的网络相册图片防盗链完美破解方法

  本文实例讲述了php实现的网络相册图片防盗链完美破解方法.分享给大家供大家参考.具体如下: 网络相册图片防盗链破解程序 - PHP版 这个防盗链破解版可以完美破解当下比较流行的: 百度相册,网易相册,360我喜欢等网站图片. 还可以实现简单的图片防盗链. 因为这个类是先进行获取远程图片, 然后再把图片发送到客户端,所以,算是进行了两次流量的传送.因此,会浪费空间流量,接下来,会开发缓存功能,这样可以实现节约流量! ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 1

php实现的网络相册图片防盗链完美破解方法_php技巧

本文实例讲述了php实现的网络相册图片防盗链完美破解方法.分享给大家供大家参考.具体如下: 网络相册图片防盗链破解程序 - PHP版 这个防盗链破解版可以完美破解当下比较流行的: 百度相册,网易相册,360我喜欢等网站图片. 还可以实现简单的图片防盗链. 因为这个类是先进行获取远程图片, 然后再把图片发送到客户端,所以,算是进行了两次流量的传送.因此,会浪费空间流量,接下来,会开发缓存功能,这样可以实现节约流量! <?php /** * 网络相册图片防盗链破解程序 - PHP版 * * 使用方法

asp.net中利用ashx实现图片防盗链的原理分析_实用技巧

 直接分析盗链原理:看下面用httpwatch截获的http发送的数据 GET /Img.ashx?img=svn_work.gif HTTP/1.1 Accept: */* Referer: http://www.jb51.net/ Accept-Language: zh-cn UA-CPU: x86 Accept-Encoding: gzip, deflate User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2; .NE

Apahce下.htaccess 重定向 301 302及图片防盗链规则

让[.htaccess]文件生效 在windows2003环境下如何配置apache支持.htaccess呢?很简单,方法如下: 一.在Apache配置文件httpd.conf中找到#LoadModule rewrite_module modules/mod_rewrite.so,去掉前面的"#"号保存. 二.配置虚拟主机文件httpd-vhosts.conf,重点颜色突出出.  代码如下 复制代码 <Directory "网站目录"> Options

asp.net中利用ashx实现图片防盗链代码_实用技巧

GET /Img.ashx?img=svn_work.gif HTTP/1.1 Accept: */* Referer: http://www.svnhost.cn/ Accept-Language: zh-cn UA-CPU: x86 Accept-Encoding: gzip, deflate User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2; .NET CLR 1.1.4322; .NET CLR 2.0.50727

图片防盗链办法

先解释一下图片防盗链和转向: 图片防盗链有什么用? 防止其它网站盗用你的图片,浪费你宝贵的流量. 图片转向有什么用? 如果你的网站以图片为主,哪天发现月底没到流量就快用光了,那就可以利用图片转向,在不修改网页的前提下,把图片下载请求转向到其它空间(比如试用主机),临时过渡. 下面开始讲解,比如你的图片都在img目录下,那就在该目录下放一个名为 .htaccess 的文件,内容如下: RewriteEngine on RewriteCond %{HTTP_REFERER} !^$ [NC] Rew

Apache图片防盗链配置方法介绍(可用.htaccess)

图片防盗链配置规则很简单 RewriteRule .*.(gif|jpg|swf|png) 说明一下其中的R.NC 和 L R 就是转向的意思 NC 指的是不区分大小写 L 的作用是指明本次转向到此结束,后续的转向不受先前判断语句的影响 5.防止 盗链的文件类型 上例中是 gif.jpg.png,而根据须要 ,可修改 或添加其他文件类型,如rar.mov等,不同文件扩展名间运用 ""分割. 使用 rewrite 技术实现 Apache 防盗链 Apache 防盗链的第一种实现方法,可以