PHP实现长轮询消息实时推送功能代码实例讲解


Posted in PHP onFebruary 26, 2021

本文实例讲述了PHP实现的消息实时推送功能。分享给大家供大家参考,具体如下:

入口文件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>
 <div class="content_box" id="content_box_title" style="border: none;">消息框</div>
 <div class="content_box" id="content_box">
 </div>
 <div 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>
 </div>
 <div class="error_tip" id="error_tip" style="color: red;">
 </div>
 <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('<div class="require">'+data.msg+'</div>');
     connect();
    }
   });
  }
  //发送消息函数
  function send(massege){
   var user =$('#username').val();
   $.getJSON('write.php',{'msg':massege,'user':user},function(data){
    if(data.sf){
     $('#content_box').append('<div class="send">'+massege+'</div>');
     $('#send_text').val('');
    }else{
     $('#error_tip').html('输入保存错误!');
    }
   });
  }
 </script>
</body>
</html>

ajax处理输入 write.php

<?php
/**
 * Created by TXM.
 * Time: 2017/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: 2017/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实现长轮询消息实时推送功能代码实例讲解的文章就介绍到这了,更多相关PHP实现长轮询消息实时推送内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

PHP 相关文章推荐
php magic_quotes_gpc的一点认识与分析
Aug 18 PHP
新手学习PHP的一些基础知识分享
Jul 27 PHP
PHP file_get_contents设置超时处理方法
Sep 30 PHP
PHP实现微信公众平台音乐点播
Mar 20 PHP
php实现转换ubb代码的方法
Jun 18 PHP
PHP读取汉字的点阵数据
Jun 22 PHP
PHP页面跳转操作实例分析(header方法)
Sep 28 PHP
PHP实现简单ajax Loading加载功能示例
Dec 28 PHP
PHP simplexml_load_string()函数实例讲解
Feb 03 PHP
Laravel框架中集成MongoDB和使用详解
Oct 17 PHP
PHP字符串与数组处理函数用法小结
Jan 07 PHP
PHP重载基础知识回顾
Sep 10 PHP
php的对象传值与引用传值代码实例讲解
Feb 26 #PHP
php并发加锁问题分析与设计代码实例讲解
Feb 26 #PHP
PHP内存溢出优化代码详解
Feb 26 #PHP
php自动加载代码实例详解
Feb 26 #PHP
PHP的重载使用魔术方法代码实例详解
Feb 26 #PHP
PHP解密支付宝小程序的加密数据、手机号的示例代码
Feb 26 #PHP
php中get_object_vars()在数组的实例用法
Feb 22 #PHP
You might like
PHP利用imagick生成组合缩略图
2016/02/19 PHP
关于php几种字符串连接的效率比较(详解)
2017/02/22 PHP
Laravel jwt 多表(多用户端)验证隔离的实现
2019/12/18 PHP
JS取request值以及自动执行使用示例
2014/02/24 Javascript
搭建pomelo 开发环境
2014/06/24 Javascript
jQuery.parseJSON(json)将JSON字符串转换成js对象
2014/07/27 Javascript
JS 打印功能代码可实现打印预览、打印设置等
2014/10/31 Javascript
JavaScript中number转换成string介绍
2014/12/31 Javascript
JavaScript动态修改网页元素内容的方法
2015/03/21 Javascript
javascript比较两个日期相差天数的方法
2015/07/24 Javascript
浅析nodejs实现Websocket的数据接收与发送
2015/11/19 NodeJs
简单实现JS对dom操作封装
2015/12/02 Javascript
js 截取或者替换字符串中的数字实现方法
2016/06/13 Javascript
bootstrap学习笔记之初识bootstrap
2016/06/21 Javascript
bootstrap-datetimepicker实现只显示到日期的方法
2016/11/25 Javascript
讲解vue-router之什么是动态路由
2018/05/28 Javascript
JavaScrip如果基于url实现图片下载
2020/07/03 Javascript
[10:34]DOTA2上海特级锦标赛全纪录
2016/03/25 DOTA
[01:32]DOTA2上海特锦赛现场采访:最想COS的英雄
2016/03/25 DOTA
总结Python编程中三条常用的技巧
2015/05/11 Python
python基础教程之Filter使用方法
2017/01/17 Python
python处理xml文件的方法小结
2017/05/02 Python
Python的numpy库中将矩阵转换为列表等函数的方法
2018/04/04 Python
python主线程与子线程的结束顺序实例解析
2019/12/17 Python
python 解决Fatal error in launcher:错误问题
2020/05/21 Python
浅谈keras保存模型中的save()和save_weights()区别
2020/05/21 Python
为什么python比较流行
2020/06/19 Python
python 统计list中各个元素出现的次数的几种方法
2021/02/20 Python
伦敦一卡通:The London Pass
2018/11/30 全球购物
Herve Leger官网:标志性绷带连衣裙等
2018/12/26 全球购物
最热门的自我评价
2013/12/30 职场文书
打架检讨书50字
2014/01/11 职场文书
小学学校评估方案
2014/06/08 职场文书
四风问题对照检查整改措施思想报告
2014/10/05 职场文书
2014年安置帮教工作总结
2014/12/11 职场文书
SQL Server内存机制浅探
2022/04/06 SQL Server