2017-10-29 4 views
0

この中で、元のドメイン名(example.com/dl.php?id=12)PHPヘッダを使って別のサーバに保存されたファイルにアクセスするにはどうすればいいですか?

に保存されているdl.phpファイルを経由してサブドメインに保存されたファイルをダウンロードする方法(dl1.example.com)がありますダウンロード可能にする必要のは、(別のサーバーからサブドメインをし、cPanelのアドオンのDNSレコードのオプションを経由して接続されている)DL1上に配置され、そのファイルの場合

dl.phpは、クライアント

URLに対するリンクをフェッチするためにPHPのヘッダでの作業db($ path)から取得し、以下の関数の入力として使用します。

downloadFile($path,$file_name, 1024, false); 
私は、ダウンロードリンク

を作るためにサブドメインを使用する場合、私は、私の問題が発生した私のマスター・ドメイン名で保存されたファイルを任意の問題を持っていない

$path="http://dl1.example.com/Lamp%20with%20phpmyadmin.mp4"; 

$ path変数は、変数以下のようなものが含まれています

私のコードのすべて:

/* List of File Types */ 
function fileTypes($extension){ 
$fileTypes['swf'] = 'application/x-shockwave-flash'; 
$fileTypes['pdf'] = 'application/pdf'; 
$fileTypes['exe'] = 'application/octet-stream'; 
$fileTypes['zip'] = 'application/zip'; 
$fileTypes['doc'] = 'application/msword'; 
$fileTypes['xls'] = 'application/vnd.ms-excel'; 
$fileTypes['ppt'] = 'application/vnd.ms-powerpoint'; 
$fileTypes['gif'] = 'image/gif'; 
$fileTypes['png'] = 'image/png'; 
$fileTypes['jpeg'] = 'image/jpg'; 
$fileTypes['jpg'] = 'image/jpg'; 
$fileTypes['rar'] = 'application/rar'; 

$fileTypes['ra'] = 'audio/x-pn-realaudio'; 
$fileTypes['ram'] = 'audio/x-pn-realaudio'; 
$fileTypes['ogg'] = 'audio/x-pn-realaudio'; 

$fileTypes['wav'] = 'video/x-msvideo'; 
$fileTypes['wmv'] = 'video/x-msvideo'; 
$fileTypes['avi'] = 'video/x-msvideo'; 
$fileTypes['asf'] = 'video/x-msvideo'; 
$fileTypes['divx'] = 'video/x-msvideo'; 

$fileTypes['mp3'] = 'audio/mpeg'; 
$fileTypes['mp4'] = 'audio/mpeg'; 
$fileTypes['mpeg'] = 'video/mpeg'; 
$fileTypes['mpg'] = 'video/mpeg'; 
$fileTypes['mpe'] = 'video/mpeg'; 
$fileTypes['mov'] = 'video/quicktime'; 
$fileTypes['swf'] = 'video/quicktime'; 
$fileTypes['3gp'] = 'video/quicktime'; 
$fileTypes['m4a'] = 'video/quicktime'; 
$fileTypes['aac'] = 'video/quicktime'; 
$fileTypes['m3u'] = 'video/quicktime'; 
return $fileTypes[$extention]; 
}; 

/* 
Parameters: downloadFile(File Location, File Name, 
max speed, is streaming 
If streaming - videos will show as videos, images as images 
instead of download prompt 
*/ 
function downloadFile($fileLocation, $fileName, $maxSpeed = 100,  $doStream = false) { 
if (connection_status() != 0) 
    return(false); 
// in some old versions this can be pereferable to get extention 
// $extension = strtolower(end(explode('.', $fileName))); 
$extension = pathinfo($fileName, PATHINFO_EXTENSION); 

$contentType = fileTypes($extension); 
header("Cache-Control: public"); 
header("Content-Transfer-Encoding: binary\n"); 
header('Content-Type: $contentType'); 

$contentDisposition = 'attachment'; 

if ($doStream == true) { 
    /* extensions to stream */ 
    $array_listen = array('mp3', 'm3u', 'm4a', 'mid', 'ogg', 'ra', 'ram', 'wm', 
     'wav', 'wma', 'aac', '3gp', 'avi', 'mov', 'mp4', 'mpeg', 'mpg', 'swf', 'wmv', 'divx', 'asf'); 
    if (in_array($extension, $array_listen)) { 
     $contentDisposition = 'inline'; 
    } 
} 

if (strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) { 
    $fileName = preg_replace('/\./', '%2e', $fileName, substr_count($fileName, '.') - 1); 
    header("Content-Disposition: $contentDisposition; 
     filename=\"$fileName\""); 
} else { 
    header("Content-Disposition: $contentDisposition; 
     filename=\"$fileName\""); 
} 

header("Accept-Ranges: bytes"); 
$range = 0; 
$size = filesize($fileLocation); 

if (isset($_SERVER['HTTP_RANGE'])) { 
    list($a, $range) = explode("=", $_SERVER['HTTP_RANGE']); 
    str_replace($range, "-", $range); 
    $size2 = $size - 1; 
    $new_length = $size - $range; 
    header("HTTP/1.1 206 Partial Content"); 
    header("Content-Length: $new_length"); 
    header("Content-Range: bytes $range$size2/$size"); 
} else { 
    $size2 = $size - 1; 
    header("Content-Range: bytes 0-$size2/$size"); 
    header("Content-Length: " . $size); 
} 

if ($size == 0) { 
    die('Zero byte file! Aborting download'); 
} 
set_magic_quotes_runtime(0); 
$fp = fopen("$fileLocation", "rb"); 

fseek($fp, $range); 

while (!feof($fp) and (connection_status() == 0)) { 
    set_time_limit(0); 
    print(fread($fp, 1024 * $maxSpeed)); 
    flush(); 
    ob_flush(); 
    sleep(1); 
} 
fclose($fp); 

return((connection_status() == 0) and ! connection_aborted()); 
} 

/* Implementation */ 
// downloadFile('path_to_file/1.mp3', '1.mp3', 1024, false); 


if(isset($_GET['i']) && is_numeric($_GET['i'])){ 
$file_id=input_security($_GET['i']); 
$linkque=mysqli_query($connection,"SELECT * FROM download_links WHERE dl_id='".$file_id."'"); 
$checkexist=mysqli_num_rows($linkque); 
$f_row=mysqli_fetch_array($linkque); 
    if($checkexist==0){ 
     echo 'Invalid file id'; 
    }else if($checkexist>=1 && $f_row['payment_model']=="free"){ 
    /* Function: download with resume/speed/stream options */ 
     $path=$f_row['url']; 
     $sep_parts = pathinfo($path); 
     $file_name = $sep_parts['basename']; 
     $file_ext = $sep_parts['extension']; 
     if (file_exists($path)) { 
     downloadFile($path,$file_name, 1024, false); 
     }else{ 
      echo "File is not exist or url is wrong."; 
     } 
}else if($checkexist>=1 && $f_row['payment_model']=="nofree"){ 
    if(isset($_SESSION['username'])){ 

    $client_id=input_security($_SESSION['username']); 
    $client_id_query="SELECT userid FROM users WHERE emailuser='".$client_id."'"; 
    $session_query=mysqli_query($connection,$client_id_query); 
    $clientidrow=mysqli_fetch_assoc($session_query); 
    $client_id=$clientidrow['user_id']; 
    $link_pid=$f_row['post_id']; 
     $userorderque=mysqli_query($connection,"SELECT * FROM user_orders WHERE post_id='".$link_pid."' AND order_client_id='".$client_id."'"); 
     $checkorderexist=mysqli_num_rows($userorderque); 
     $checktobuy_row=mysqli_fetch_array($userorderque); 


     if($checkorderexist>=1 && $checktobuy_row['paid']==1){ 

     $path=$f_row['url']; 
     $sep_parts = pathinfo($path); 
     $file_name = $sep_parts['basename']; 
     $file_ext = $sep_parts['extension']; 
     if (file_exists($path)){ 
     //echo "thank you for purchase and support us. You can download now."; 
      downloadFile($path,$file_name, 1024, false); 
     }else{ 
      echo "File is not exist or url is wrong."; 
     } 
     }else if($checkorderexist>=1 && $checktobuy_row['paid']==0){ 
      echo "You Need to pay for download this file"; 
     } 
    }else{ 
     echo "This file needs to login"; 
    } 



}else{ 
    echo "You don't have permission to download this file please purchase this product and trying to download again"; 
    } 
}else{ 
    header('Location: index.php'); 
} 

がどのように私は私の上に保存されている私のスクリプトからサブドメインとしての私のドメイン名(dl1.example.com)に接続して、私の別のサーバーに保存されたファイルへのアクセス権を持つことができますドバイnの名前(私のマスターWebサーバーホスト(example.com)を意味する)?

私は任意のヘルプ

+1

あなたは何をしようとしているのか明確ではありません。 – Scriptonomy

+0

私は製品のリンクを共有したいが、支払う顧客のためだけだ。 –

答えて

0

をいただければ幸いあなたのコミュニケーションの流れがどのように100%明確ではないが、あなたの説明から、あなただけのクロスドメインの問題に対処します。

header("Access-Control-Allow-Origin: *"); 
異なる環境を使用して

良い例がここで見つけることができます:

https://enable-cors.org/

あなたはダウンロードのためにサーバーのレスポンスにこのヘッダを追加して、サーバー上のクロスドメインの呼び出しを可能にすることにより、上に行くことができるかもしれません
+0

ヘッダー( "Access-Control-Allow-Origin:*");うまくいきません、あなたは私に簡単な一例を教えてもらえますか? –

+0

私はこれについて今私たちはしばらくの間チャットできると思います。クロスドメインが本当にあなたの問題であるかどうか、あなたのケースの説明は明らかにしません。そうであれば、あなたの特別な環境のための特定の解決策についてあなた自身を調べるか、それに応じて詳細を提供する質問を更新する必要があります – Harry

関連する問題