|
復制代碼 代碼如下:
<?php
$url = "http://www.jb51.NET/";
$ctx = stream_context_create(array(
'http' => array('timeout' => 5,
'proxy' => 'tcp://60.175.203.243:8080',
'request_fulluri' => True,)
)
);
$result = file_get_contents($url, False, $ctx);
echo $result;
?>
另外一種 curl 的方式使用代理的方法:
復制代碼 代碼如下:
function postPage($url)
{
$response = "";
$rd=rand(1,4);
$proxy='http://221.214.27.253:808';
if($rd==2) $proxy='http://222.77.14.56:8088';
if($rd==3) $proxy='http://202.98.123.126:8080';
if($rd==4) $proxy='http://60.14.97.38:8080';
if($url != "") {
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_PROXY, $proxy);
$response = curl_exec($ch);
if(curl_errno($ch)) $response = "";
curl_close($ch);
}
return $response;
}
用file_get_contents解決ajax垮域問題
在ajax運用中有時候會垮域調用文件,而瀏覽器為了安全會默認給這種操作提出警告,甚至直接阻止。如果是IE會彈出一個警告窗口,詢問你是否繼續操作,只有你同意了IE才會調用垮域的文件。而其它瀏覽器,如火狐、Opera默認設置下則會直接提示錯誤,阻止調用外域文件。這會給用戶不好的操作體驗,如果想通過用戶修改瀏覽器的安全設置來解決這個問題是不現實的,最好是在服務器端解決。
在服務器端可以使用一個同域的文件做為代理文件,這個代理文件將獲得外域文件的內容,然后再傳遞給ajax。這樣ajax就不是調用外域文件,而是調用同域的這個代理文件,安全問題也就解決了。
如果你的服務器端支持php的話,可以使用file_get_contents這個函數,看到它的名稱就已經知道它有獲得其它文件內容的功能了。它的詳細用法可以參看php官方網站上的file_get_contents用法一頁,下面是它的簡單實例。
復制代碼 代碼如下:
<?php
$serverAddress = 'http://s.jb51.NET';
//獲得外域文件內容
$randomNumber = file_get_contents($serverAddress);
//輸出內容
echo $randomNumber;
?>
php技術:PHP下通過file_get_contents的代理使用方法,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。