ホームページ > バックエンド開発 > PHPチュートリアル > PHP の ajax ロングポーリングとは何ですか?

PHP の ajax ロングポーリングとは何ですか?

一个新手
リリース: 2023-03-15 18:48:01
オリジナル
3350 人が閲覧しました

PHP における Ajax ロングポーリングは、クライアントが Ajax リクエストを開始すると、サーバーが復帰する条件がトリガーされるまでサーバーはリクエストを一時停止し、サーバーが戻る前にクライアントは保留状態になり、待機していると理解できます。 ajax ロングポーリングはクライアント側の無駄なリクエストを減らすことができますが、サーバー側の負担は大きくなります。

PHP の ajax ロングポーリングとは何ですか?

ajax ロングポーリングとは何ですか? PHP で Ajax ロングポーリングを実装するにはどうすればよいですか? 以下の記事で紹介しています。困っている友人が参考になれば幸いです。

いわゆる ajax ロングポーリングは、クライアントが ajax リクエストを開始し、サーバーが戻る前に条件がトリガーされるまでサーバーが (ループを通じて) リクエストを一時停止することを意味します。保留中であり、サーバーが戻るのを待っています。

ajax ロングポーリングはクライアントからの無駄なリクエストを減らすことができますが、サーバーへの負荷は大きくなります。また、WebSocket を使用してプッシュを実装することもできますが、互換性が低く、ブラウザによっては WebSocket をサポートしていない場合があります。

PHP は Ajax ロングポーリングを実装します

ここでは、AJAX を使用して data.PHP ページをリクエストし、「success」の値を取得します。リクエスト時間は 80 秒に達します。この 80 秒間にサーバーから「success」が返されなかった場合、データが返されるか「success」の値が 0 になって接続が閉じられるまで、接続ステータスはそのままになります。接続を閉じた後、次のリクエストを続行します。

index.html

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">  
    <head>  
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">  
        <script  type="text/javascript" src="http://s1.hqbcdn.com/??lib/jquery/jquery-1.7.2.min.js"></script>  
    </head>  
    <body>  
    <p id="msg"></p>  
    <input id="btn" type="button" value="测试" />  
    <script  type="text/javascript" >  
        $(function(){  
            $("#btn").bind("click",{btn:$("#btn")},function(evdata){  
                $.ajax({  
                    type:"POST",  
                    dataType:"json",  
                    url:"data.php",  
                    timeout:80000,     //ajax请求超时时间80秒  
                    data:{time:"80"}, //40秒后无论结果服务器都返回数据  
                    success:function(data,textStatus){  
                        //从服务器得到数据,显示数据并继续查询  
                        if(data.success=="1"){  
                            $("#msg").append("<br>[有数据]"+data.text);  
                            evdata.data.btn.click();  
                        }  
                        //未从服务器得到数据,继续查询  
                        if(data.success=="0"){  
                            $("#msg").append("<br>[无数据]");  
                            evdata.data.btn.click();  
                        }  
                    },  
                    //Ajax请求超时,继续查询  
                    error:function(XMLHttpRequest,textStatus,errorThrown){  
                        if(textStatus=="timeout"){  
                            $("#msg").append("<br>[超时]");  
                            evdata.data.btn.click();  
                        }  
                    }  

                });  
            });  

        });  
    </script>  
    </body>  
    </html>
ログイン後にコピー

これは無限ループです。ループの終了条件は、戻り結果を取得して Json データを返すことです。

そして、$_POST[‘time’] パラメーターを受け入れて、リソースの過剰な浪費を避けるためにループのタイムアウトを制限します。 (ブラウザを閉じると、ブラウザはサーバーにメッセージを送信せず、使用がループで継続する可能性があります)

data.php

    <?php  
        if(empty($_POST[&#39;time&#39;]))exit();        
        set_time_limit(0);//无限请求超时时间        
        $i=0;        
        while (true){        
            //sleep(1);        
            usleep(500000);//0.5秒        
            $i++;        
            //若得到数据则马上返回数据给客服端,并结束本次请求        
            $rand=rand(1,999);        
            if($rand<=15){        
                $arr=array(&#39;success&#39;=>"1",&#39;name&#39;=>&#39;xiaoyu&#39;,&#39;text&#39;=>$rand);        
                echo json_encode($arr);        
                exit();        
            }        
            //服务器($_POST[&#39;time&#39;]*0.5)秒后告诉客服端无数据        
            if($i==$_POST[&#39;time&#39;]){        
                $arr=array(&#39;success&#39;=>"0",&#39;name&#39;=>&#39;xiaoyu&#39;,&#39;text&#39;=>$rand);        
                echo json_encode($arr);        
                exit();        
            }        
        }     
    ?>
ログイン後にコピー

動作効果: 写真では、データなしのリクエスト時間が到達していることがわかります。 40S。40S のリクエスト時間が取得された場合、データリクエストはクローズされます。終了後、次のリクエストに進みます。

PHP の ajax ロングポーリングとは何ですか?

PHP の ajax ロングポーリングとは何ですか?

関連知識の詳細については、PHP 中国語 Web サイト をご覧ください。 !

以上がPHP の ajax ロングポーリングとは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート