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之第二天
Oct 09 PHP
一个更简单的无限级分类菜单代码
Jan 16 PHP
php各种编码集详解和以及在什么情况下进行使用
Sep 11 PHP
php下载excel无法打开的解决方法
Dec 24 PHP
php调用C代码的实现方法
Mar 11 PHP
PHP获取中英混合字符串长度的方法
Jun 07 PHP
PHP中可以自动分割查询字符的Parse_str函数使用示例
Jul 25 PHP
PHP实现简单实用的验证码类
Jul 29 PHP
php实现json编码的方法
Jul 30 PHP
PHP自定义函数实现格式化秒的方法
Sep 14 PHP
php+ajax实现商品对比功能示例
Apr 13 PHP
laravel-admin的图片删除实例
Sep 30 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支持中文字符串分割的函数
2015/05/28 PHP
在php中设置session用memcache来存储的方法总结
2016/01/14 PHP
jquery validate poshytip 自定义样式
2012/11/26 Javascript
JS 精确统计网站访问量的实例代码
2013/07/05 Javascript
jQuery实现拖拽页面元素并将其保存到cookie的方法
2016/06/12 Javascript
JavaScript表单焦点自动切换代码
2016/07/24 Javascript
关于动态执行代码(js的Eval)实例详解
2016/08/15 Javascript
Vue表单验证插件的制作过程
2017/04/01 Javascript
浅谈angular.js跨域post解决方案
2017/08/30 Javascript
JavaScript 自定义事件之我见
2017/09/25 Javascript
BootStrap点击保存后实现模态框自动关闭的思路(模态框)
2017/09/26 Javascript
JS实现简单获取最近7天和最近3天日期的方法
2018/04/18 Javascript
微信小程序自定义轮播图
2018/11/04 Javascript
JavaScript偏函数与柯里化实例详解
2019/03/27 Javascript
JavaScript设计模式--简单工厂模式定义与应用案例详解
2020/05/23 Javascript
JavaScript实现像雪花一样的Hexaflake分形
2020/07/07 Javascript
vue中后端做Excel导出功能返回数据流前端的处理操作
2020/09/08 Javascript
python实现的多线程端口扫描功能示例
2017/01/21 Python
Python爬豆瓣电影实例
2018/02/23 Python
Python多线程处理实例详解【单进程/多进程】
2019/01/30 Python
python爬虫基础教程:requests库(二)代码实例
2019/04/09 Python
Python多进程multiprocessing、进程池用法实例分析
2020/03/24 Python
新加坡网上化妆品店:Best Buy World
2018/05/18 全球购物
全球500多个机场的接送服务:Suntransfers
2019/06/03 全球购物
在数据文件自动增长时,自动增长是否会阻塞对文件的更新
2014/05/01 面试题
项目考察欢迎辞
2014/01/17 职场文书
国旗下的讲话演讲稿
2014/05/08 职场文书
2014年人事工作总结范文
2014/11/19 职场文书
汽车转让协议书
2015/01/29 职场文书
公司奖励通知
2015/04/21 职场文书
狼牙山五壮士观后感
2015/06/09 职场文书
2015年语言文字工作总结
2015/07/23 职场文书
高中信息技术教学反思
2016/02/16 职场文书
人民调解协议书
2016/03/21 职场文书
Python获取字典中某个key的value
2022/04/13 Python
CSS list-style-type属性使用方法
2023/05/21 HTML / CSS