Cette fois, je vais vous apporter une explication détaillée des étapes pour implémenter le push de messages en temps réel basé sur le push anti-ajax en PHP Quelles sont les précautions pour que PHP implémente le push de messages en temps réel. basé sur le push anti-ajax. Voici des cas pratiques.
Fichier d'entréeindex.html
<!DOCTYPE HTML> <html> <head> <title>反ajax推送</title> <style> .send{color:#555;text-align: left;} .require{color:blue;text-align: right;} .content_box{text-align: center;margin: 20px; border: 1px solid #ddd;padding: 20px;} </style> <script src="http://code.jQuery.com/jquery-1.11.2.min.js"></script> </head> <body> <p class="content_box" id="content_box_title" style="border: none;">消息框</p> <p class="content_box" id="content_box"> </p> <p style="width: 450px;margin: 0 auto;"> <select id="username" style="font-size: 20px;"> <option value="1" selected="selected">1</option> <option value="2">2</option> </select> <input type="text" style="font-size: 20px;" value="" id="send_text"> <button id="btn_send" style="font-size: 20px;">发送</button> <button id="btn_link" style="font-size: 20px">连接</button> </p> <p class="error_tip" id="error_tip" style="color: red;"> </p> <script> $(function(){ //发送消息 $('#btn_send').click(function(){ var send_text = $('#send_text').val(); if(send_text.length <= 0){ $('#error_tip').html('不能输入空值'); }else{ send(send_text); } }); //按回车键发送消息 $('#send_text').on('keyup',function(e){ if(e.keyCode == 13){ $('#btn_send').trigger('click'); } }); //建立通讯链接 $('#btn_link').click(function(){ connect(); var _this = $(this); _this.attr('disabled',true); _this.html('已连接'); }); }); //建立通讯连接函数 function connect(){ $('#content_box_title').html($('#username').val()+'的消息窗口'); $.ajax({ data:{'user':$('#username').val()}, url:'ajaxPush.PHP', type:'get', timeout:0, dataType:'json', success:function(data){ $('#content_box').append('<p class="require">'+data.msg+'</p>'); connect(); } }); } //发送消息函数 function send(massege){ var user =$('#username').val(); $.getJSON('write.php',{'msg':massege,'user':user},function(data){ if(data.sf){ $('#content_box').append('<p class="send">'+massege+'</p>'); $('#send_text').val(''); }else{ $('#error_tip').html('输入保存错误!'); } }); } </script> </body> </html>
entrée de traitement ajax write.php
<?php /** * Created by TXM. * Time: 2015/4/18 13:13 * function: */ $filename = dirname(FILE).'/data.txt'; $isread_file = dirname(FILE).'/isread.txt'; $user = dirname(FILE).'/user.txt'; //写入消息,消息未读,谁发送的消息 file_put_contents($filename,$_GET['msg']); file_put_contents($isread_file,'0'); file_put_contents($user,$_GET['user']); echo json_encode(array('sf'=>true));
Pousse d'interrogation longue ajaxPush.php
<?php /** * Created by TXM. * Time: 2015/4/18 13:12 * function: */ $filename = dirname(FILE).'/data.txt'; $isread_file = dirname(FILE).'/isread.txt'; $userfile = dirname(FILE).'/user.txt'; $get_user = $_GET['user'] == '1'?'2':'1'; $msg=''; while(1){ $msg = file_get_contents($filename); $isread = file_get_contents($isread_file); $user = file_get_contents($userfile); //是对方发送的消息,设置消息已读,退出循环。 if($isread == '0' && $get_user == $user){ file_put_contents($isread_file,'1'); break; } sleep(1); } echo json_encode(array('msg'=>$msg));
Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !
Lecture recommandée :
Étapes de mise en œuvre du calcul de conversion hexadécimale PHP
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!