程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> 基於php實現長連接的方法與注意事項的問題

基於php實現長連接的方法與注意事項的問題

編輯:PHP綜合

php可以通過set_time_limit(0);來取消php腳步超時限制,從而達到長連接的效果。

例子代碼如下:
復制代碼 代碼如下:
<?php

echo "每隔3秒輸出一次<br />";

set_time_limit(0); //保證php程序運行不超時退出

while(1) {

   echo date("H:i:s")."<br />";

   ob_flush();

   flush(); //刷新並輸出PHP緩沖數據

   sleep(3); //延遲3秒

}

?>

示例代碼2:
復制代碼 代碼如下:
set_time_limit(0);

header("Connection:Keep-Alive");

header("Proxy-Connection:Keep-Alive");

for($i=0;$i<60;$i++) {

   print 'text'.$i.'<br>';

   ob_flush();

   flush();

   sleep(1);

   clearstatcache();

}

這裡調用了ob_flush();   flush();來強制輸出數據到緩沖區,這樣就能在腳步返回之前及時返回數據到浏覽器。另外不沖下flush和ob_flush的使用上有一些特別容易犯錯的地方,造成無法刷新輸出緩沖。

一. flush和ob_flush的正確順序,正確應是,先ob_flush再flush,如下:

ob_flush();

flush();

如果Web服務器的操作系統是windows系統,那順序顛倒或者不使用ob_flush()也不會出現問題。但是在Linux系統上就無法刷新輸出緩沖。
 

二. 使用ob_flush()前,確保前面的內容大小足夠4069字符。

一些Web服務器的output_buffering默認是4069字符或者更大,即輸出內容必須達到4069字符服務器才會flush刷新輸出緩沖,為了確保flush有效,最好在ob_flush()函數前有以下語句:

print str_repeat(" ", 4096);

以確保到達output_buffering值。
復制代碼 代碼如下:
for ($i=10; $i>0; $i--)

{

echo $i.'<br />';

ob_flush();

flush();

sleep(1);

}
ob_end_flush();

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved