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

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

這幾天在寫一個(gè)php防盜鏈外部資源下載處理函數(shù),昨天晚上剛完成編寫,中間遇到了些問題,這里就不詳述了;
以下是自寫的簡(jiǎn)單的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)閉一個(gè)已打開的文件指針
    $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ǎng)執(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)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 免费毛片在线视频 | 亚洲女人影院想要爱 | 伊人久久大香 | 日韩视频91 | 在线观看视频www在线观看 | 久久66热re国产毛片基地 | 欧美亚洲激情 | 精品久久久久久国产 | 国产成人啪午夜精品网站 | 91插插插插插 | 国产欧美在线观看精品一区二区 | 超清乱人伦中文视频在线 | 四虎在线最新永久免费播放 | 成人午夜视频在线观看 | 一区二区三区四区视频 | 中文字幕久久久久 | 国产成人激烈叫床声视频对白 | 国产免费私拍一区二区三区 | 色综合久久伊人 | 波多野结衣在线影院 | 久久综合色网 | 亚洲欧美日韩在线精品一区二区 | 国产高清自拍 | 国产亚洲精品一品区99热 | 一区二区三区高清在线 | 久久免费区一区二区三波多野 | 色干干| 国产亚洲高清视频 | 亚洲欧美综合视频 | 夜色天堂| 日本一区二区三区免费看 | 精品国产成人a在线观看 | 国产高清一区二区三区四区 | 四虎国产精品永久地址99新强 | 国产亚洲精品福利片 | 亚洲欧美日韩在线2020 | 久久国产99 | a级精品国产片在线观看 | 久久久亚洲精品蜜桃臀 | 国产一区在线mmai | 久久精品大片 |