如何使用PHP獲取網絡上文件


<?php
//設置我們將要使用的文件
$srcurl = "https://localhost/index.php";
$tempfilename = "tempindex.html";
$targetfilename = "index.html";
?>

<br /> Generating <br />

Generating …
<?php
//首先刪除上次操作可能遺留下來的臨時文件。
//這個過程可能會提示錯誤,所以我們使用@以防止報錯。
@unlink($tempfilename);
//通過一個URL的請求裝入動態版本。
//在我們接收到相關內容之前,Web服務器會對PHP進行處理
//(因為本質上我們是在模擬一個Web瀏覽器),
//所以我們將獲得的是一個靜態的HTML頁面。
//r指出我們隻要求對這個“文件”進行讀操作。
$dynpage = fopen($srcurl, r);
//處理錯誤
if (!$dynpage) {
echo("
Unable to load $srcurl. Static page ".
"update aborted!
");
exit();
}
//將這個URL的內容讀入到一個PHP變量中。
//指定我們將讀取1MB的數據(超過這個數據量一般是意味著出錯瞭)。
$htmldata = fread($dynpage, 1024*1024);

//當我們完成工作後,關閉到源“文件”的連接。
fclose($dynpage);
//打開臨時文件(同時在這個過程中建立)以用來寫入(註意w的用法).
$tempfile = fopen($tempfilename, w);
//處理錯誤
if (!$tempfile) {
echo("
Unable to open temporary file ".
"($tempfilename) for writing. Static page ".
"update aborted!
");
exit();
}
//將靜態頁面的數據寫入到臨時文件中
fwrite($tempfile, $htmldata);
//完成寫入後,關閉臨時文件。
fclose($tempfile);
//如果到瞭這裡,我們應該已經成功地寫好瞭一個臨時文件,
//現在我們可以用它來覆蓋原來的靜態頁面瞭。
$ok = copy($tempfilename, $targetfilename);
//最後刪除這個臨時文件。
unlink($tempfilename);
?>
Static page successfully updated!

You May Also Like