中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

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

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

復制代碼 代碼如下:
<?php
/**
 *
 * 防盜鏈外部資源下載處理類
 *
 * @link   http://jb51.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}/r/nFileUrl   = {$FileInfo['Content-Location']}/r/nFileSize   = {$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./n/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);                                                                                 // 設置文件最長執行時間
     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://jb51.NET';
// 許可來路域名列表
$allowUrl = array(
 'jb51.NET',
);
$BurglarDow = new BurglarDow($dowUrl,$Location,$allowUrl);
$BurglarDow -> dow();

php技術PHP寫的資源下載防盜鏈類分享,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲一二三在线 | 日本在线免费看最新的电影 | 久久精品一级 | 日韩成人精品一区二区三区 | 亚洲精品视频在线 | 亚洲精品一 | 亚洲日韩视频 | 国产精品精品3d动漫 | 国产精品日韩欧美一区二区三区 | 美女久久久久久久久 | 免费一区 | 成人高清视频在线观看 | 一区二区久久 | 精品国产一区二区三区久久久蜜月 | 亚洲国产精品一区二区三区 | 国产综合在线视频 | 精品一区二区三区四区在线 | 一级日韩 | 九九av| 欧美精品久久 | 国产乱码精品一区二区三区中文 | 美女在线视频一区二区三区 | 国产成人在线视频免费观看 | 久久av一区 | 欧美日韩精品一区二区三区蜜桃 | 日韩成人高清在线 | 日韩一 | 爽爽免费视频 | 91综合网 | 91视频在线 | 新91视频网| 日韩看片| 国产美女一区二区 | 久久久www成人免费无遮挡大片 | 国产成人一区二区三区精 | 日本又色又爽又黄又高潮 | 成人激情视频免费观看 | 2022精品国偷自产免费观看 | 欧美人成在线视频 | 国产美女视频黄 | 久久精品免费观看 |