首頁  >  文章  >  後端開發  >  PHP如何實作非同步呼叫方法

PHP如何實作非同步呼叫方法

小云云
小云云原創
2018-03-22 11:45:378499瀏覽

瀏覽器和伺服器之間是透過 HTTP 協定進行連接通訊的。這是一種基於請求和回應模型的協定。瀏覽器透過 URL 向伺服器發起請求,Web 伺服器接收到請求,執行一段程序,然後做出回應,並發送相應的html代碼給客戶端。

這就有了一個問題,Web 伺服器執行一段程序,可能幾毫秒就完成,也可能幾分鐘都完不成。如果程式執行緩慢,使用者可能沒有耐心等下去,就關閉瀏覽器了。

而有的時候,我們更本不關心這些耗時的腳本的返回結果,但卻還要等他執行完返回,才能繼續下一步。 那麼有沒有什麼辦法,只是簡單的觸發呼叫這些耗時的腳本然後就繼續下一步,讓這些耗時的腳本在服務端慢慢執行?

經過試驗,總結出來幾種方法,和大家share: 1. 最簡單的辦法,就是在傳回給客戶端的HTML程式碼中,嵌入AJAX調用,或者,嵌入一個img標籤,src指向要執行的耗時腳本。 這種方法最簡單,也最快。伺服器端不用做任何的呼叫。 但缺點是,一般來說Ajax都應該在onLoad以後觸發,也就是說,用戶點開頁面後,就關閉,那就不會觸發我們的後台腳本了。 而使用img標籤的話,這種方式不能稱為嚴格意義上的非同步執行。使用者瀏覽器會長時間等待php腳本的執行完成,也就是使用者瀏覽器的狀態列一直顯示還在load。 當然,也可以使用其他的類似原理的方法,例如script標籤等等。

2. popen()

resource popen ( string command, string mode ); //開啟一個指向進程的管道,該進程由派生給定的 command 命令執行而產生。開啟一個指向進程的管道,該進程由派生給定的 command 命令執行而產生。

所以可以透過呼叫它,但忽略它的輸出。

pclose(popen("/home/xinchen/backend.php &", 'r'));

這個方法避免了第一個方法的缺點,而且也很快。但問題是,這種方法不能透過HTTP協定請求另外的一個WebService,只能執行本地的腳本檔案。並且只能單向打開,無法穿著大量參數給被呼叫腳本。
而且如果,訪問量很高的時候,會產生大量的進程。如果使用到了外部資源,還要自己考慮競爭。

3. 使用CURL
這個方法,設定CUROPT_TIMEOUT為1(最小為1,鬱悶)。也就是說,客戶端至少必須等待1秒鐘。

$ch = curl_init();
 
$curl_opt = array(CURLOPT_URL, 'http://www.example.com/backend.php',
                            CURLOPT_RETURNTRANSFER, 1,
                            CURLOPT_TIMEOUT, 1,);
 
curl_setopt_array($ch, $curl_opt);
 
curl_exec($ch);
 
curl_close($ch);

4. 使用fsockopen
這個方法應該是最完美的,但缺點是,你需要自己拼出HTTP的header部分。

$fp = fsockopen("www.example.com", 80, $errno, $errstr, 30);
if (!$fp) {
    echo "$errstr ($errno)<br />\n";
} else {
    $out = "GET /backend.php  / HTTP/1.1\r\n";
    $out .= "Host: www.example.com\r\n";
    $out .= "Connection: Close\r\n\r\n";
 
    fwrite($fp, $out);
    /*忽略执行结果
    while (!feof($fp)) {
        echo fgets($fp, 128);
    }*/
    fclose($fp);
}

所以,整體來看,最好用,最簡單的還是第一種方法。
最完美的應該是最後一種,但比較複雜。

相關推薦:

JavaScript 非同步呼叫實例分析

#php實作非同步呼叫多執行緒的方法

關於JavaScript 非同步呼叫方法

#

以上是PHP如何實作非同步呼叫方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn