php弹幕技术轮询,PHP实现长轮询消息实时推送功能代码
入口文件index.html
反ajax推送
.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;}
1
2
发送
连接
$(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('
');
connect();
}
});
}
//发送消息函数
function send(massege){
var user =$('#username').val();
$.getJSON('write.php',{'msg':massege,'user':user},function(data){
if(data.sf){
$('#content_box').append('
');
$('#send_text').val('');
}else{
$('#error_tip').html('输入保存错误!');
}
});
}
ajax处理输入 write.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
/**
* 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消息实时推送技术,基于HTTP协议之WEB消息实时推送技术原理及实现
很早就想写一些关于网页消息实时推送技术方面的文章,但是由于最近实在忙,没有时间去写文章.本文主要讲解基于 HTTP1.1 协议的 WEB 推送的技术原理及实现.本人曾经在工作的时候也有做过一些用到网页 ...
- 技术分享| 基于RTM 实现的呼叫邀请如何添加推送功能?
RTM 实时消息服务,解决了在线实时信令的传递,如何配合推送服务,去做离线通知功能一直困扰着开发者,本文从 RTM 的功能以及响应机制入手,教大家如何通过RTM配合第三方推送服务来完成离线消息通知. ...
- ajax长轮询tornado,Tornado长轮询和WebSocket
Http协议是一种请求响应式协议, 不允许服务端主动向客户端发送信息. 短轮询是一种简单的实现服务端推送消息的解决方案, 客户端以一定间隔自动向服务端发送刷新请求, 服务端返回要推送的消息作为响应. ...
- php主动推送弹幕_百万在线的美拍直播弹幕系统的实时推送技术实践之路
1.内容概述 1.jpg (30.13 KB, 下载次数: 321) 2 年前 上传 直播弹幕是直播系统的核心功能之一.如何迅速作出一个有很好扩展性的弹幕系统?如何应对业务迅速发展?相信很多工程师/架 ...
- WEB 实时推送技术总结
前言 随着 Web 的发展,用户对于 Web 的实时推送要求也越来越高 ,比如,工业运行监控.Web 在线通讯.即时报价系统.在线游戏等,都需要将后台发生的变化主动地.实时地传送到浏览器端,而不需要用 ...
- Web 实时推送技术如何弥补 HTTP 协议的缺陷? | 技术头条
作者 | 浪里行舟 责编 | 郭芮 人工智能的现状及今后发展趋势如何? https://edu.csdn.net/topic/ai30?utm_source=csdn_bw 随着 Web 的发展,用 ...
- Web 实时推送技术的总结
前言 随着 Web 的发展,用户对于 Web 的实时推送要求也越来越高 ,比如,工业运行监控.Web 在线通讯.即时报价系统.在线游戏等,都需要将后台发生的变化主动地.实时地传送到浏览器端,而不需要用 ...
- html页面推送功能的实现,想实现Web页面内容自动更新?你需要了解WEB实时推送技术!...
随着 Web 的发展,用户对于 Web 的实时推送要求也越来越高 ,比如,工业运行监控.Web 在线通讯.即时报价系统.在线游戏等,都需要将后台发生的变化主动地.实时地传送到浏览器端,而不需要用户手动 ...
- php主动推送弹幕_php实现通知的实时推送
其实这个内容,我在就搞过,只是没记录过.正好最近,项目中遇到了,记录一下,方便有同样需求的小伙伴,也参考下.先说一下我的需求,我们一个呼叫系统,电话接通之后,呼叫体系统会推送一个通知到我指定的url上 ...
最新文章
- java 打电话_第四十二篇----拨打电话
- php中icon,php中iconv函数的使用方法
- centos中python2.7被覆盖,yum,python重新安装
- python enumerate 行号 序号
- java.lang.IllegalArgumentException: There is no PasswordEncoder mapped for the id null
- all index range ref eq_ref const system 索引type说明
- Delphi APP 開發入門(五)GPS 定位功能
- Vue 组件间通信方法汇总
- spring cloud 定时任务
- python中5个json库的速度对比,你猜对了吗
- 只有22%的人做对了这道数据分析题,你来试试吗?
- c#中判断对象为空的几种方式(字符串等)
- 使用WebDeployment Project改善VS2005发布网站问题 [系列导读]
- redis基础学习(一)— 配置项
- 学在LINUX下编程(转)
- 计算机组成原理问题集合
- matlab势场动态栅格路径规划,融栅格法和人工势场法的机器人三维路径规划
- calibre部署指南:docker一键部署calibre在线书库
- Virtualbox虚拟机设置共享文件夹
- Vulnerabilities in multi-factor authentication:多因素身份验证漏洞