1. 程式人生 > >PHP+jquery ajax 實現實時的輸出顯示

PHP+jquery ajax 實現實時的輸出顯示

一、html程式碼。利用$.ajax的xhr屬性,以及js中對於XMLHttpRequest的onreadystatechange事件,實時的從後端獲取並處理。

參考連結:ajax如何實現、readyState五中狀態的含義

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta charset="utf-8">
</head>
<body>
    <div><button id="ontimeoutputBtn">及時輸出</button></div>
    <div id="ontimeoutputArea" style="border: 1px solid red"></div>
</body>
<script type="text/javascript" src="./jquery-3.3.1.min.js"></script>
<script type="text/javascript">
//   readyState總共有5個狀態值,分別為0~4
//   0  未初始化狀態:此時,已經建立了一個XMLHttpRequest物件
//   1  準備傳送狀態:此時,已經呼叫了XMLHttpRequest物件的open方法,並且XMLHttpRequest物件已經準備好將一個請求傳送到伺服器端
//   2  已經發送狀態:此時,已經通過send方法把一個請求傳送到伺服器端,但是還沒有收到一個響應
//   3  正在接收狀態:此時,已經接收到HTTP響應頭部資訊,但是訊息體部分還沒有完全接收到
//   4  完成響應狀態:此時,已經完成了HTTP響應的接收
    $('#ontimeoutputBtn').click(function(){
        $.ajax({
            url :'./tree.php'
            ,type:'get'
            ,data:{}
            ,success:function(res){
                console.log('這裡用jq提供的方法處理');
                console.log(res);
            }
            ,xhr:function(){//返回一個更強大的XMLHttpRequest的物件
                if (window.XMLHttpRequest) {
                    //主流瀏覽器提供了XMLHttpRequest物件
                    var xhr = new XMLHttpRequest();
                }else if (window.ActiveXObject) {
                    //低版本的IE瀏覽器沒有提供XMLHttpRequest物件
                    //所以必須使用IE瀏覽器的特定實現ActiveXObject
                    var xhr = new ActiveXObject("Microsoft.XMLHTTP");
                }
                //繫結事件
                xhr.onreadystatechange = function () {
                    if (xhr.readyState === 4 && xhr.status === 200) {
                        //獲取成功後執行操作
                        //資料在xhr.responseText
                        //這裡使用js原生的處理方式
                        // console.log('success');
                    }
                    if(xhr.readyState === 3){
                        var html = "<p style='border:1px solid red;'>"+xhr.responseText+"</p>";
                        $('#ontimeoutputArea').html(html);
                    }
                }
                return xhr;                
            } 
        });
    });
</script>
</html>

 

二、php端的程式碼。ob_flush和flush要同時執行,另外只能這樣的呼叫順序。先ob_flush在flush

function onTimeOutput($str){
   echo $str;
   ob_flush();
   flush();
}
echo 'Begin ...<br />';
for( $i = 0 ; $i < 10 ; $i++ )
{
  $str = $i . '<br />';
  onTimeOutput($str);
  sleep(2);
}
echo 'End ...<br />';

三、如果在linux環境,如果伺服器是nginx的話,要加個配置。參考連結:

nginx伺服器ob_flush和flush不起作用

proxy_buffering off;
gzip off;
fastcgi_keep_conn on;

可能你不知道這三項配置加到哪裡,分享一下。至於放在nginx.conf裡還是放在vhost的站點配置裡,看自己了

server {
        listen 80 default_server;
        listen [::]:80 default_server ipv6only=on;
        root /var/www;
        index index.html index.htm;
        # Make site accessible from http://localhost/
        server_name localhost;

        #在這裡的呢        
        proxy_buffering off;
        gzip off;
        fastcgi_keep_conn on;
        #在這裡的呢        

        location / {
                # First attempt to serve request as file, then
        }
}

四、https環境上述程式碼可能不能執行。因為nginx的ssl_buffer_size 配置的原因,預設16k的快取。你可以要麼配置nginx設定這個值的大小,要麼輸出的時候多加一行

echo str_repeat(' ',1024*16);