当前位置:知识百科 > 正文

php怎么推送数据

更新时间:2025-01-03 01:30 阅读量:88680

php

use Workerman\Worker;

require_once './Workerman/Autoloader.php';

// 这里进程数必须设置为1

$worker-count = 1;

// worker进程启动后建立一个内部通讯端口

$worker-onWorkerStart = function($worker)

{

// 开启一个内部端口,方便内部系统推送数据,Text协议格式 文本◆换行符

$inner_text_worker-onMessage = function($connection, $buffer)

global $worker;

// $data数组格式,里面有uid,表示向那个uid的页面推送数据

$data = json_decode($buffer, true);

$uid = $data['uid'];

// 通过workerman,向uid的页面推送数据

$ret = sendMessageByUid($uid, $buffer);

// 返回推送结果

$connection-send($ret ? 'ok' : 'fail');

};

$inner_text_worker-listen();

// 新增加一个属性,用来保存uid到connection的映射

$worker-uidConnections = array();

$worker-onMessage = function($connection, $data)use($worker)

if(!isset($connection-uid))

// 没验证的话把第一个包当做uid(这里为了方便演示,没做真正的验证)

$connection-uid = $data;

/* 保存uid到connection的映射,这样可以方便的通过uid查找connection,

* 实现针对特定uid推送数据

*/

$worker-uidConnections[$connection-uid] = $connection;

return;

}

$worker-onClose = function($connection)use($worker)

if(isset($connection-uid))

// 连接断开时删除映射

unset($worker-uidConnections[$connection-uid]);

// 向所有验证的用户推送数据

function broadcast($message)

foreach($worker-uidConnections as $connection)

$connection-send($message);

// 针对uid推送数据

function sendMessageByUid($uid, $message)

if(isset($worker-uidConnections[$uid]))

$connection = $worker-uidConnections[$uid];

return true;

return false;

// 运行所有的worker(其实当前只定义了一个)

Worker::runAll();

启动后端服务

php push.php start -d

前端接收推送的js代码

ws.onopen = function(){

var uid = 'uid1';

ws.send(uid);

ws.onmessage = function(e){

alert(e.data);

后端推送消息的代码

// 建立socket连接到内部推送端口

// 推送的数据,包含uid字段,表示是给这个uid推送

fwrite($client, json_encode($data)."\n");

// 读取推送结果

这里的uid不一定是用户的id,也可以理解为任务id即 taskid

以上代码亲测可以直接使用

php 怎么做 内部的消息推送呢

可以用第三方软件极光推送来实现.对于定制化需求较强的,或者想拥有自己推送平台的开发者,极光提供全功能的私有云方案.

极光推送快速开始步骤:

①.、到极光推送官方网站注册开发者帐号;

php实现websocket实时消息推送

第一段:socket协议的简介

WebSocket是什么,有什么优点

WebSocket是一个持久化的协议,这是相对于http非持久化来说的.应用层协议

举个简单的例子,http1.0的生命周期是以request作为界定的,也就是一个request,一个response,对于http来说,本次client与server的会话到此结束;而在http1.1中,稍微有所改进,即添加了keep-alive,也就是在一个http连接中可以进行多个request请求和多个response接受操作.然而在实时通信中,并没有多大的作用,http只能由client发起请求,server才能返回信息,即server不能主动向client推送信息,无法满足实时通信的要求.而WebSocket可以进行持久化连接,即client只需进行一次握手,成功后即可持续进行数据通信,值得关注的是WebSocket实现client与server之间全双工通信,即server端有数据更新时可以主动推送给client端.

第二段:介绍client与server之间的socket连接原理

①.、下面是一个演示client和server之间建立WebSocket连接时握手部分

a、client建立WebSocket时向服务器端请求的信息

GET /chat HTTP/1.1

Host: server.example.com

Upgrade: websocket //告诉服务器现在发送的是WebSocket协议

Connection: Upgrade

Sec-WebSocket-Protocol: chat, superchat

Origin:

b、服务器获取到client请求的信息后,根据WebSocket协议对数据进行处理并返回,其中要对Sec-WebSocket-Key进行加密等操作

HTTP/1.1 101 Switching Protocols

Sec-WebSocket-Protocol: chat

第三段:PHP中建立websocket的过程讲解

SocketService.php:

web.html:

如何在php中用百度云推送进行消息的推送

在php中用百度云推送进行消息的推送的方法

①Android端推送

// 创建Android SDK对象.

$asdk = new \Vendor\pushsdk\PushSDK(); //自己引入百度云推送的SDK,官网上有文档详细介绍

$channelId = $channelrows;

$message = array (

// 消息的标题.

'title' = $title,

// 消息内容

'description' = $brief,

//传广告id,可以通过键值对的形式传多个值

'custom_content'=array('id'=$id),

);

// 设置消息类型为通知类型.

$opts = array (

'msg_type' = 1,

// 向目标设备发送一条消息(群发,指的是通过前面的筛选之后的channelId进行的大量的推送)

$rs = $asdk - pushBatchUniMsg($channelId, $message, $opts);

// 判断返回值,当发送失败时, $rs的结果为false, 可以通过getError来获得错误信息.

if($rs === false)

print_r($asdk-getLastErrorCode());

print_r($asdk-getLastErrorMsg());

else{echo "success!";}

// 创建Ios SDK对象.

$isdk = new \Vendor\ipushsdk\IPushSDK();

'aps' = array(

'alert' = $brief, // 消息内容

),

'id' =$id, //账号ID,这边能够以键值对的形式可以传多个值

// 设置消息类型为 通知类型.

msg_type' = 1,

$rs = $isdk-createTag('tag_new'); //通过创建标签的方式来实现群发的功能

if($rs !== false)

if($isdk - addDevicesToTag('tag_new',$channelId) !== false)

// 发送

$rs = $isdk - pushMsgToTag('tag_new',$message,$opts);

//删除标签

$delRs = $isdk-deleteTag('tag_new');

//判断返回值,当发送失败时, $rs的结果为false, 可以通过getError来获得错误信息.

print_r($isdk-getLastErrorCode());

print_r($isdk-getLastErrorMsg());