一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

PHP寫的資源下載防盜鏈類分享

這幾天在寫一個php防盜鏈外部資源下載處理函數(shù),昨天晚上剛完成編寫,中間遇到了些問題,這里就不詳述了;
以下是自寫的簡單的php防盜鏈處理類(重新整理編寫成類文件,以便后期改進(jìn));

復(fù)制代碼 代碼如下:
<?php
/**
 *
 * 防盜鏈外部資源下載處理類
 *
 * @link   http://jb51.NET
 *
 */
class BurglarDow{
 /**
     * 初始許可下載狀態(tài)
     * @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();
 /**
     * 初始轉(zhuǎn)跳地址
     * @var    Location
     * @access private
     */
 private $Location   =  null;

 public function __construct($dowUrl,$Location,array $allowUrl){
  // 初始下載地址
  $this->dowUrl   = $dowUrl;
  // 初始許可資源取用域名列表
  $this->allowUrl = $allowUrl;
  // 初始轉(zhuǎn)跳地址
  $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;                                                                                 // 下載許可狀態(tài)為:真
   }
  }
  unset($this->allowUrl,$this->RemoteUrl);                                                                      // 釋放內(nèi)存變量
 }

 /**
  * 防盜鏈資源下載
  * @access public
  * @return mixed
  */
 public function dow(){
  $FileInfo = get_headers($this->dowUrl,1);                                                                     // 獲取遠(yuǎn)程文件頭部信息

  if(true === $this->allow){                                                                                    // 判斷是否許可下載資源
   //判斷配置文件是否存在
   if(is_file('Config.ini')){
    $FileCon = parse_ini_file('Config.ini');
   }else{
    $FileName   =  basename($FileInfo['Content-Location']);
    $FileConStr = "FileName  = {$FileName}/r/nFileUrl   = {$FileInfo['Content-Location']}/r/nFileSize   = {$FileInfo['Content-Length']}";
    $handle = fopen ('Config.ini', "wb");                                                                 // Config.ini文件不存在則創(chuàng)建文件
    if (fwrite ($handle, $FileConStr) == FALSE) {                                                         // 數(shù)據(jù)寫入文件
     echo "File creation failed ...";
    }
    fclose ($handle);                                                                                     // 關(guān)閉一個已打開的文件指針
    $FileCon = parse_ini_file('Config.ini');
   }
   if(!empty($$this->dowUrl)){
    $fp = @fopen($$this->dowUrl, "rb");                                                                   // 二進(jìn)制模式讀取文件
    if (!$fp)
      exit("Download a mistake./n/n");

    // 輸出遠(yuǎn)程資源
    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);                                                                                 // 設(shè)置文件最長執(zhí)行時(shí)間
     echo fread($fp, 1024);                                                                             // 輸出文件
     flush();                                                                                           // 輸出緩沖
     ob_flush();                                                                                        // 輸出緩沖區(qū)中的內(nèi)容
    }
    fclose($fp);
   }else{
    header("HTTP/1.1 404 Not Found");
   }
  }else{
   header("HTTP/1.1 301 Moved Permanently");
   header("Location: ".$this->Location);
  }
 }
}
// 遠(yuǎn)程資源地址
$dowUrl = 'http://dldir1.qq.com/qqfile/qq/QQ5.1/10055/QQ5.1.exe';
// 轉(zhuǎn)跳地址
$Location = 'http://jb51.NET';
// 許可來路域名列表
$allowUrl = array(
 'jb51.NET',
);
$BurglarDow = new BurglarDow($dowUrl,$Location,$allowUrl);
$BurglarDow -> dow();

php技術(shù)PHP寫的資源下載防盜鏈類分享,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产高清视频免费人人爱 | 久久久青草青青亚洲国产免观 | 国产成人在线视频网站 | 成年wwxx视频免费中文 | 午夜国产精品福利在线观看 | 国产99区 | 国产精品99一区二区三区 | 加勒比色综合久久久久久久久 | 91亚洲精品国产自在现线 | 国产精品美女一级在线观看 | 日韩综合久久 | 四虎影视亚洲精品 | 四虎永久精品免费观看 | 四虎国产精品免费观看 | 久久久久久久综合 | 精品国产高清不卡毛片 | 日产精品一区二区三区免费 | 精品国产一区二区三区免费看 | 国内精品久久久久激情影院 | 午夜视频一区二区 | 国产一区中文字幕在线观看 | mmmxxx黄大片| 亚洲一区亚洲二区亚洲三区 | 久久亚洲私人国产精品 | 日韩在线视频不卡 | 永久免费aavv视频播放 | 国产亚洲美女精品久久久久狼 | wwwav在线| 一区一精品| 欧美日本韩国一区二区 | 国产精品福利在线播放 | 国产福利微拍精品一区二区 | 欧美成人午夜精品免费福利 | 国产精品福利无圣光一区二区 | 精品一区二区三区在线观看 | 欧美另类videosbestse | 99在线观看视频免费精品9 | 男人精品网站一区二区三区 | 性久久久久久 | 色又色| 激情欧美一区二区三区 |