php web 消息推送框架,一个基于WebSocket的WEB消息推送框架

一个基于WebSocket的WEB消息推送框架

web-msg-sender是一款web长连接推送框架,采用PHPSocket.IO开发,基于WebSocket长连接通讯,如果浏览器不支持WebSocket则自动转用comet推送。 通过后台推送消息,消息可以即时推送到客户端,非轮询,实时性非常好,性能很高。

特点:

多浏览器支持

支持针对单个用户推送消息

支持向所有用户推送消息

长连接推送(websocket或者comet),消息即时到达

支持在线用户数实时统计展示

支持在线页面数实时统计展示

支持跨域推送

下载

https://github.com/walkor/web-msg-sender

WEB消息推送框架

接收消息页面:http://www.workerman.net:2123/

推送接口url:http://www.workerman.net:2121/?type=publish&to=uid&content=content

其中to为接收消息的uid,如果传空则向所有人推送消息 content 为消息内容

Linux环境安装启动

1、下载web-msg-sender,并解压缩到任意目录

2、启动workermanphp start.php start -d如下图

3、浏览器访问端口http://ip:2123或者http://域名:2123,例如 http://workerman.net:2123如图:(如果无法访问请检查服务器防火墙)

前端测试:

支持跨域推送,开发者可以不用建立服务端,直接使用线上的推送服务测试,只要引入js文件并设置下端口及回调即可,例如在任意站点中加入如下代码即可收到消息并统计数据:

// 连接服务端

var socket = io('http://workerman.net:2120');

// uid可以是自己网站的用户id,以便针对uid推送以及统计在线人数

uid = 123;

// socket连接后以uid登录

socket.on('connect', function(){

socket.emit('login', uid);

});

// 后端推送来消息时

socket.on('new_msg', function(msg){

console.log("收到消息:"+msg);

});

// 后端推送来在线数据时

socket.on('update_online_count', function(online_stat){

console.log(online_stat);

});

后端调用api向任意用户推送:<?php

// 指明给谁推送,为空表示向所有在线用户推送

$to_uid = "";

// 推送的url地址,上线时改成自己的服务器地址

$push_api_url = "http://workerman.net:2121/";

$post_data = array(

"type" => "publish",

"content" => "这个是推送的测试数据",

"to" => $to_uid,

);

$ch = curl_init ();

curl_setopt ( $ch, CURLOPT_URL, $push_api_url );

curl_setopt ( $ch, CURLOPT_POST, 1 );

curl_setopt ( $ch, CURLOPT_HEADER, 0 );

curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 );

curl_setopt ( $ch, CURLOPT_POSTFIELDS, $post_data );

$return = curl_exec ( $ch );

curl_close ( $ch );

var_export($return);

相关文章:

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WebSocket 消息基于 HTTP 和 TCP 协议,它允许服务器主动向客户端消息,实现了双向通信。下面是 WebSocket 消息的原理: 1. 客户端发起 WebSocket 连接请求:客户端通过发一个特殊的 HTTP 请求头部信息(包含 Upgrade: websocket 字段),来请求与服务器建立 WebSocket 连接。 2. 服务器响应 WebSocket 连接请求:当服务器收到客户端的 WebSocket 连接请求后,会以 HTTP 101 状态码响应客户端,并携带一些特殊的响应头部信息(包含 Upgrade: websocket 字段)。这样,服务器和客户端就建立了一个双向通信的连接。 3. 双方通过 WebSocket 连接进行通信:一旦 WebSocket 连接建立成功,双方可以通过该连接进行实时的双向通信,可以发文本、二进制数据等。 4. 服务器主动消息:与传统的 HTTP 请求不同,WebSocket 允许服务器主动向客户端消息,而不需要等待客户端发起请求。服务器可以随时将消息给客户端,客户端收到后可以及时处理。 5. 客户端接收消息并处理:客户端通过监听 WebSocket 连接上的消息事件,一旦收到服务器消息,就可以进行相应的处理,例如更新页面内容、展示通知等。 需要注意的是,WebSocket 基于 TCP 协议,具有较低的延迟和较高的效率,适用于实时通信场景。同时,WebSocket 需要服务器和客户端都支持,并且需要一定的网络带宽支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值