您好,欢迎访问一九零五行业门户网

PHP基于反ajax推送实现消息实时推送步骤详解

这次给大家带来php基于反ajax推送实现消息实时推送步骤详解,php基于反ajax推送实现消息实时推送的注意事项有哪些,下面就是实战案例,一起来看一下。
入口文件index.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>
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));
长轮询推送 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));
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
php开发api接口安全验证步骤详解
php进制相互转换计算实现步骤
以上就是php基于反ajax推送实现消息实时推送步骤详解的详细内容。
其它类似信息

推荐信息