通过http推送消息给socket,socket服务再向客户端推送
<?php /* * Socket推送 * 请用守护进程方式启动php msgservice.php & (socket只支持linux) * 默认使用SWOOLE_PROCESS模式,echo终端是禁止的,如果要观察日志,保存到log中. * status=1,小程序推送 * status=2,点餐机->socket->身份识别 * status=3,socket->点餐机->推送订单 * status=4,点餐机->socket->告知消息已经处理 */ class WebsocketServer { public $server; //主机群 private $client=array(); //消息群 private $clientmsg=array(); public function __construct() { //01.绑定网卡 $this->server = new swoole_websocket_server("0.0.0.0", 9502); //02.主动握手 $this->server->on('open', function (swoole_websocket_server $server, $request) { //echo "server: handshake success with fd{$request->fd}\n"; }); //03.消息获取 $this->server->on('message', function (swoole_websocket_server $server, $frame) { //echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n"; //3.1.记录客户端信息 $data=json_decode($frame->data,true); if(isset($data['status']) && $data['status']==2){ $rev=array( 'hostfd'=>$frame->fd,//'在swoole中是顺序' 'shopid'=>$data['shopid'], ); //新来的客户端,看看是否有你的订单 foreach ($this->clientmsg as $value) { if($value['shopid']==$rev['shopid']){ //echo 'have'; $data=json_encode($value); $server->push($frame->fd,$data); break; } } //多个终端只识别第一个 $isnew=1; foreach ($this->client as $value) { if($value['shopid']==$rev['shopid']){ $isnew=0; break; } } if($isnew){ array_push($this->client,$rev); } else { //echo 'This client duplication,now client num:'.count($this->client).'\n'; } } //3.2.点餐机已经处理的消息直接清理 if( isset($data['status']) && $data['status']==3){ $orderid=$data['orderid']; foreach ($this->clientmsg as $key => $value) { if($value['orderid']==$orderid){ unset($this->clientmsg[$key]); array_merge($this->clientmsg); //echo 'order is reved!'; break; } } } }); //04.断开事件,清理无效主机 $this->server->on('close', function ($ser, $fd) { foreach ($this->client as $key => $value) { if($value['hostfd']==$fd){ unset($this->client[$key]); array_merge($this->client); } } //echo "client {$fd} closed,now client num:".count($this->client).'\n'; }); //05.小程序推送,实例不走nginx/apache,请访问本进程端口 $this->server->on('request', function ($request, $response) { //带有推送表示的主体 if(isset($request->post['status']) && $request->post['status']==1) { //接收小程序推送 $rev=array( 'type'=> $request->post['type'], 'shopid' =>$request->post['shopid'], 'orderid'=>$request->post['orderid'], ); $response->end('ok'); //直接尝试发送给点餐机 foreach ($this->client as $value) { if($value['shopid']==$rev['shopid']){ $data=json_encode($rev); $this->server->push($value['hostfd'],$data); break; } } //入列 array_push($this->clientmsg,$rev); } }); $this->server->start(); } } new WebsocketServer();
<?php $base64_body = substr(strstr($_POST[base64],','),1); $data= base64_decode($base64_body); file_put_contents($_SERVER[&q...
header() 函数向客户端发送原始的 HTTP 报头。(官方解释)通俗的讲header函数将参数中的字符串作为服务端的响应头来返回给客户端。什么是服务端的响应头?打开谷歌浏览器看看network中的请求response header信息即可。更多的参数百度response header即可浏览器...
md5/sha1+salt方式是目前各大cms常用的加密方式,虽然salt安全,但是各大md5网站也在研究这个方向,那么我们应该选择password_hash动态hash来助力,一种密码有多种hash结果.看代码模拟登陆.<?php //01.注册 $user ='zhang...
php官方的超全局变量$_SERVER['PHP_SELF']也能直接获取,只不过如果url参数太多也会获取。下面提供一个方法获取/* * 获取当前PHP文件名称 */ if (!function_exists('phpself...
最近在公司开发一个新的项目假设项目域名是a.com,需要接入b.com的单点登陆系统。(1).首先我们会在a.com的登陆页面用iframe引入b.com来显示登陆界面,实际上登陆验证操作都是在b.com上面(2).当b.com验证通过,会在前端ajax请求a.com的回调地址,这个回调地址目的就是...