北京尚网汇智科技有限公司
您当前所在的位置:尚网汇智网站建设 > PHP技术 > 文章详细
网站建设知识
NEWS
联系我们
  • 网站建设服务电话
  • 400-883-2887
  • 公司地址:北京市昌平科技园区创意大厦2-806
  • 服务项目
    高端网站建设
    移动/微信网站建设
    手机APP开发
    OA/ERP业务系统开发
    网站维护托管
    CMS模板制作

    【PHP代码】PHP防盗链外部资源下载处理类

    发布时间:2014-07-18 00:27:15

    这几天在写一个PHP防盗链外部资源下载处理函数,昨天晚上刚完成编写,中间遇到了些问题,这里就不详述了;
    以下是自写的简单的PHP防盗链处理类(重新整理编写成类文件,以便后期改进);
    <?php
    /**
     *
     * 防盗链外部资源下载处理类
     *
     * @author 清风 <xrcc_bk@126.com>
     * @link   http://blog.emtalk.net
     *
     */
    class BurglarDow{
     /**
         * 初始许可下载状态
         * @var    allow
         * @access private
         */
     private $allow      =  false;
     /**
         * 初始下载地址
         * @var    dowUrl
         * @access private
         */
     private $dowUrl     =  null;
     /**
         * 初始来路域名
         * @var    RemoteUrl
         * @access private
         */
     private $RemoteUrl  =  null;
     /**
         * 初始许可资源取用域名列表
         * @var    allowUrl
         * @access private
         */
     private $allowUrl   =  array();
     /**
         * 初始转跳地址
         * @var    Location
         * @access private
         */
     private $Location   =  null;

     public function __construct($dowUrl,$Location,array $allowUrl){
      // 初始下载地址
      $this->dowUrl   = $dowUrl;
      // 初始许可资源取用域名列表
      $this->allowUrl = $allowUrl;
      // 初始转跳地址
      $this->Location = $Location;

      $this->RemoteUrl = @parse_url($_SERVER['HTTP_REFERER']);                                                      // 获取来路域名
      if(!is_array($this->RemoteUrl))
       header('HTTP/1.1 301 Moved Permanently');
       header('Location: '.$this->Location);

      if(isset($this->RemoteUrl['host'])){
       if(in_array($this->RemoteUrl['host'],$this->allowUrl)){                                                   // 判断是否来至许可域名
        $this->allow  = true;                                                                                 // 下载许可状态为:真
       }
      }
      unset($this->allowUrl,$this->RemoteUrl);                                                                      // 释放内存变量
     }

     /**
      * 防盗链资源下载
      * @access public
      * @return mixed
      */
     public function dow(){
      $FileInfo = get_headers($this->dowUrl,1);                                                                     // 获取远程文件头部信息

      if(true === $this->allow){                                                                                    // 判断是否许可下载资源
       //判断配置文件是否存在
       if(is_file('Config.ini')){
        $FileCon = parse_ini_file('Config.ini');
       }else{
        $FileName   =  basename($FileInfo['Content-Location']);
        $FileConStr = 'FileName  = {$FileName} FileUrl   = {$FileInfo['Content-Location']} FileSize   = {$FileInfo['Content-Length']}';
        $handle = fopen ('Config.ini', 'wb');                                                                 // Config.ini文件不存在则创建文件
        if (fwrite ($handle, $FileConStr) == FALSE) {                                                         // 数据写入文件
         echo 'File creation failed ...';
        }
        fclose ($handle);                                                                                     // 关闭一个已打开的文件指针
        $FileCon = parse_ini_file('Config.ini');
       }
       if(!empty($$this->dowUrl)){
        $fp = @fopen($$this->dowUrl, 'rb');                                                                   // 二进制模式读取文件
        if (!$fp)
          exit('Download a mistake. ');

        // 输出远程资源
        header('Content-type:text/html;charset=utf-8');
        header('Content-Description: File Transfer');
        header('Content-Type: application/octet-stream');
        header('Content-Disposition: attachment; filename='.$FileCon['FileName']);
        header('Accept-Ranges: bytes');
        header('Content-Transfer-Encoding: binary');
        header('Expires: 0');
        header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
        header('Pragma: public');
        header('Content-Length: '.$FileCon['FileSize']);
        while (!feof($fp)){
         set_time_limit(0);                                                                                 // 设置文件最长执行时间
         echo fread($fp, 1024);                                                                             // 输出文件
         flush();                                                                                           // 输出缓冲
         ob_flush();                                                                                        // 输出缓冲区中的内容
        }
        fclose($fp);
       }else{
        header('HTTP/1.1 404 Not Found');
       }
      }else{
       header('HTTP/1.1 301 Moved Permanently');
       header('Location: '.$this->Location);
      }
     }
    }
    // 远程资源地址
    $dowUrl = 'http://dldir1.qq.com/qqfile/qq/QQ5.1/10055/QQ5.1.exe';
    // 转跳地址
    $Location = 'http://blog.emtalk.net';
    // 许可来路域名列表
    $allowUrl = array(
     'blog.emtalk.net',
    );
    $BurglarDow = new BurglarDow($dowUrl,$Location,$allowUrl);
    $BurglarDow -> dow();
    有何不足之处,还望访友们多指点指点;

     


    文章出自:北京网站建设公司-尚网汇智 https://www.net2006.com 如转载请注明出处!
    咨询服务热线
    400-883-2887
    客服电话:400-883-2887  传真:010-51654992  E-mail:support@net2006.com
    本站设计已受版权保护,任何公司及个人不得复制,违者将依法追究责任,特此声明。

    Copyright © 2005-2018 北京尚网汇智科技有限公司 版权所有 京ICP备13031271号
    查找内容: