


Implementing Ajax long polling (LongPoll) based on jQuery and PHP_PHP tutorial
In the traditional AJAX polling method, the client queries the server for the latest data at user-defined intervals. This method of pulling data requires a short time interval to ensure the accuracy of the data, but if the time interval is too short, the customer service side will send multiple requests to the server in a short period of time.
Reverse AJAX, which is called long polling or COMET. The server and client need to maintain a long-term request, which allows the server to return messages to the client when there is data.
The requested time reaches 80 seconds. If no 'success' is returned from the server during these 80 seconds, the connection status will remain until data is returned or the value of 'success' is 0 before the connection is closed. After closing the connection, continue with the next request.
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><</span><span class="tag-name">div</span><span> </span><span class="attribute">id</span><span>=</span><span class="attribute-value">"msg"</span><span class="tag">></span><span class="tag"></</span><span class="tag-name">div</span><span class="tag">></span><span> </span></span></li> <li> <span class="tag"><</span><span class="tag-name">input</span><span> </span><span class="attribute">id</span><span>=</span><span class="attribute-value">"btn"</span><span> </span><span class="attribute">type</span><span>=</span><span class="attribute-value">"button"</span><span> </span><span class="attribute">value</span><span>=</span><span class="attribute-value">"测试"</span><span> </span><span class="tag">/></span><span> </span> </li> </ol>
PHP
Here is an infinite loop. The end condition of the loop is to obtain the return result and return Json data. And accepts the $_POST['time'] parameter to limit the loop timeout to avoid excessive waste of resources. (The browser will not send a message to the server when it is closed, and the use may continue in a loop)<ol class="dp-c"> <li class="alt"><span><span>$(</span><span class="keyword">function</span><span>(){ </span></span></li> <li> <span> $(</span><span class="string">"#btn"</span><span>).bind(</span><span class="string">"click"</span><span>,{btn:$(</span><span class="string">"#btn"</span><span>)},</span><span class="keyword">function</span><span>(evdata){ </span> </li> <li class="alt"><span> $.ajax({ </span></li> <li> <span> type:</span><span class="string">"POST"</span><span>, </span> </li> <li class="alt"> <span> dataType:</span><span class="string">"json"</span><span>, </span> </li> <li> <span> url:</span><span class="string">"data.php"</span><span>, </span> </li> <li class="alt"> <span> timeout:80000, </span><span class="comment">//ajax请求超时时间80秒 </span><span> </span> </li> <li> <span> data:{time:</span><span class="string">"80"</span><span>}, </span><span class="comment">//40秒后无论结果服务器都返回数据 </span><span> </span> </li> <li class="alt"> <span> success:</span><span class="keyword">function</span><span>(data,textStatus){ </span> </li> <li> <span> </span><span class="comment">//从服务器得到数据,显示数据并继续查询 </span><span> </span> </li> <li class="alt"> <span> </span><span class="keyword">if</span><span>(data.success==</span><span class="string">"1"</span><span>){ </span> </li> <li> <span> $(</span><span class="string">"#msg"</span><span>).append(</span><span class="string">"<br>[有数据]"</span><span>+data.text); </span> </li> <li class="alt"><span> evdata.data.btn.click(); </span></li> <li><span> } </span></li> <li class="alt"> <span> </span><span class="comment">//未从服务器得到数据,继续查询 </span><span> </span> </li> <li> <span> </span><span class="keyword">if</span><span>(data.success==</span><span class="string">"0"</span><span>){ </span> </li> <li class="alt"> <span> $(</span><span class="string">"#msg"</span><span>).append(</span><span class="string">"<br>[无数据]"</span><span>); </span> </li> <li><span> evdata.data.btn.click(); </span></li> <li class="alt"><span> } </span></li> <li><span> }, </span></li> <li class="alt"> <span> </span><span class="comment">//Ajax请求超时,继续查询 </span><span> </span> </li> <li> <span> error:</span><span class="keyword">function</span><span>(XMLHttpRequest,textStatus,errorThrown){ </span> </li> <li class="alt"> <span> </span><span class="keyword">if</span><span>(textStatus==</span><span class="string">"timeout"</span><span>){ </span> </li> <li> <span> $(</span><span class="string">"#msg"</span><span>).append(</span><span class="string">"<br>[超时]"</span><span>); </span> </li> <li class="alt"><span> evdata.data.btn.click(); </span></li> <li><span> } </span></li> <li class="alt"><span> } </span></li> <li><span> </span></li> <li class="alt"><span> }); </span></li> <li><span> }); </span></li> <li class="alt"><span> </span></li> <li><span>}); </span></li> </ol>
Operating effect: In the picture, you can see that the request time without data reaches 40S. In the 40S request, if Request to close when data is obtained.
<ol class="dp-c"> <li class="alt"><span><span class="keyword">if</span><span>(</span><span class="func">empty</span><span class="keyword">empty</span><span>(</span><span class="vars">$_POST</span><span>[</span><span class="string">'time'</span><span>]))</span><span class="func">exit</span><span>(); </span></span></li> <li> <span>set_time_limit(0);</span><span class="comment">//无限请求超时时间 </span><span> </span> </li> <li class="alt"> <span class="vars">$i</span><span>=0; </span> </li> <li> <span class="keyword">while</span><span> (true){ </span> </li> <li class="alt"> <span> </span><span class="comment">//sleep(1); </span><span> </span> </li> <li> <span> usleep(500000);</span><span class="comment">//0.5秒 </span><span> </span> </li> <li class="alt"> <span> </span><span class="vars">$i</span><span>++; </span> </li> <li><span> </span></li> <li class="alt"> <span> </span><span class="comment">//若得到数据则马上返回数据给客服端,并结束本次请求 </span><span> </span> </li> <li> <span> </span><span class="vars">$rand</span><span>=rand(1,999); </span> </li> <li class="alt"> <span> </span><span class="keyword">if</span><span>(</span><span class="vars">$rand</span><span><=15){ </span></li><li><span> </span><span class="vars">$arr</span><span>=</span><span class="keyword">array</span><span>(</span><span class="string">'success'</span><span>=></span><span class="string">"1"</span><span>,</span><span class="string">'name'</span><span>=></span><span class="string">'xiaocai'</span><span>,</span><span class="string">'text'</span><span>=></span><span class="vars">$rand</span><span>); </span> </li> <li class="alt"> <span> </span><span class="func">echo</span><span> json_encode(</span><span class="vars">$arr</span><span>); </span> </li> <li> <span> </span><span class="func">exit</span><span>(); </span> </li> <li class="alt"><span> } </span></li> <li><span> </span></li> <li class="alt"> <span> </span><span class="comment">//服务器($_POST['time']*0.5)秒后告诉客服端无数据 </span><span> </span> </li> <li> <span> </span><span class="keyword">if</span><span>(</span><span class="vars">$i</span><span>==</span><span class="vars">$_POST</span><span>[</span><span class="string">'time'</span><span>]){ </span> </li> <li class="alt"> <span> </span><span class="vars">$arr</span><span>=</span><span class="keyword">array</span><span>(</span><span class="string">'success'</span><span>=></span><span class="string">"0"</span><span>,</span><span class="string">'name'</span><span>=></span><span class="string">'xiaocai'</span><span>,</span><span class="string">'text'</span><span>=></span><span class="vars">$rand</span><span>); </span> </li> <li> <span> </span><span class="func">echo</span><span> json_encode(</span><span class="vars">$arr</span><span>); </span> </li> <li class="alt"> <span> </span><span class="func">exit</span><span>(); </span> </li> <li><span> } </span></li> <li class="alt"><span>} </span></li> </ol>
www.bkjia.com
true
http: //www.bkjia.com/PHPjc/445814.html

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c
