thinkphp5.0整合phpsocketio完整攻略(绕坑)


Posted in PHP onOctober 12, 2018

PHPSocket.IO是基于workerman开发的php版本的socket.IO服务。可用于服务器消息的推送、聊天室、客服系统的开发

使用环境: thinkphp5.0

项目需求

前端下单,后台接受,并立即做出提示。例如:美团外卖,客户端下单成功后,商家端就会立即有接单语音提示。

开发环境

  • thinkphp5.0
  • phpsocketio

(由于需要启动socket服务,所以需在能够满足shell的环境下使用)

socketio 优势

这里只是我的观点,毕竟没有怎么深入研究socketio,所以只是浅显的一点总结:

  • 减小服务器IO负载
  • 长连接比ajax轮询靠谱
  • 服务稳定,支持动态

初略的看了一下,内存占用很小,而且只有1个进程,根据官方报道来说1个进程也能容纳1W人次的高并发,所以,对于我的项目来说,已经绰绰有余

官方文档

https://github.com/walkor/phpsocket.io

开始开发

安装 phpsocketio

首先cd到thinkphp的项目根目录。使用以下命令

composer require workerman/phpsocket.io

( 这里composer不做解释,如果有什么问题,度娘一下,应该能够解决 )

安装好以后,vendor文件夹下面应该就有一个workerman的文件夹,如果存在,就恭喜你,已经安装完毕了

服务入口文件

回到项目根目录,新建server.php,开始编辑

#!/usr/bin/env php
<?php
define('APP_PATH', __DIR__ . '/application/');
define('BIND_MODULE','socketio/Server/index');
// 加载框架引导文件
require __DIR__ . '/thinkphp/start.php';

这里只要写好就OK。后续的所有东西,可以忽略他的存在

创建服务控制器

上一步的server.php文件里面,模块绑定到了'socketio/Server/index',这里就需要我们手动创建了。为了能理解,我用目录展示

├─application      应用目录
│ ├─socketio      新创建目录
│ │ ├─controller   
│ │ │ ├─Server.php  启动文件

Server.php

入口文件只是绑定到了这个控制器,所以这个是整个socketio的核心。

<?php
/*
 * (c) U.E Dream Development Studio
 *
 * Author: 李益达 - Ekey.Lee <ekey.lee@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace app\socketio\controller;

require_once VENDOR_PATH . "workerman/phpsocket.io/src/autoload.php";

use PHPSocketIO\SocketIO;
use Workerman\Worker;

class Server
{

  public function index()
  {
    $io = new SocketIO(8080);//socket的端口
    $io->on('workerStart', function () use ($io) {
      $inner_http_worker = new Worker('http://0.0.0.0:5880');//这里IP不用改变,用的内网通讯,端口不能与socket端口想通
      $inner_http_worker->onMessage = function ($http_connection, $data) use ($io) {
        
        $io->emit('new_msg', '44444');//这里写了固定数据,请根据自己项目需求去做调整,不懂这里的可以看看官方文档,很清楚
        $http_connection->send('ok');
      };
      $inner_http_worker->listen();
    });

    // 当有客户端连接时
    $io->on('connection', function ($socket) use ($io) {
      // 定义chat message事件回调函数
      $socket->on('chat message', function ($msg) use ($io) {
        // 触发所有客户端定义的chat message from server事件
        $io->emit('chat message from server', $msg);
      });
    });

    Worker::runAll();
  }
}

创建API 触发socketio

同样你可以在socketio下面新建一个API控制器,这里仅供测试

public function api()
  {
    // 推送的url地址,使用自己的服务器地址
    $push_api_url = "http://0.0.0.0:5880";//这里同样不需要更改IP。只是端口一定需要和server.php onworker的一样
    $post_data = array(
      "type" => "publish",
      "content" => "这个是推送的测试数据",
    );
    $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 );
    curl_setopt ($ch, CURLOPT_HTTPHEADER, array("Expect:"));
    $return = curl_exec ( $ch );
    curl_close ( $ch );
    var_export($return);
  }

现在有了server服务端,API触发端,接下来就需要显示出来了,就是我们的前端

前端

现在要写的就是,商家端收到的提示。之前写的server服务端提供phpsocketio监控与socket服务,API提供事件触发,也就是有人下单后的触发,下单作为事件去触发服务器socket,让他回应到前端

代码开始前请注意:这里的端口和域名比较的绕

<script src='//cdn.bootcss.com/socket.io/1.3.7/socket.io.js'></script>
 <script>
      // 连接服务端
      var socket = io('http://xxxx.com:8080');//这里请填写你的域名,外网,端口为socket端口
     // 后端推送来消息时
      socket.on('new_msg', function (msg) {//这里的new_msg请一定要注意,官方文档都写的是content,但是后端发送的自定义是new_msg,后端定义成new_msg,前端却接受content的字段。所以是接受不了的
        swal({ title: "包厢点餐提醒", text: "哆啦a梦包厢有新订单" })
        //console.log("收到消息:" + msg);
      });

</script>

以上有两个我之前出问题的地方

  • 端口与域名:域名是外网的域名,当然是需要和你的socket服务在同一个IP下面,即:你的socket部署在114.114.114.114的IP下面。这个域名就必须是在114.114.114.114的IP下面。端口则是后端服务里面new SocketIO的端口了。
  • socket.on()文档里面都是socket.on('content',function(msg){....}),但是可以看我们Server.php里面$io->emit('new_msg', '');这里自定义的事件明明叫做new_msg,但是却被写成了content,可能是本人眼拙,没有看清楚,但是也提醒一下,这里确实要注意回调事件名

部署完毕开始运行

现在所有的文件就算是部署好了,进入服务器管理,打开shell。cd到项目根目录。然后执行php server.php start

php server.php start 启动
php server.php stop 停止
php server.php restart 重启
php server.php status 当前服务状态

总结

这次只作为工作总结,因为时间紧迫我也没有好好去研究socketio的更多东西,可能有些地方有纰漏,但是我100%保证这是本人亲自测试,所提到的坑点,都是我一步一步踩过去的。如果有说错的欢迎指教 ^_^

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP 远程关机实现代码
Nov 10 PHP
jQuery EasyUI API 中文文档 - DateBox日期框
Oct 15 PHP
PHP Session 变量的使用方法详解与实例代码
Sep 11 PHP
php求正负数数组中连续元素最大值示例
Apr 11 PHP
php使用for语句输出三角形的方法
Jun 09 PHP
CodeIgniter与PHP5.6的兼容问题
Jul 16 PHP
ECSHOP在PHP5.5及高版本上报错的解决方法
Aug 31 PHP
PHP中使用substr()截取字符串出现中文乱码问题该怎么办
Oct 21 PHP
PHP版本升级到7.x后wordpress的一些修改及wordpress技巧
Dec 25 PHP
php中bind_param()函数用法分析
Mar 28 PHP
PHP实现打包zip并下载功能
Jun 12 PHP
ThinkPHP框架实现的邮箱激活功能示例
Jun 15 PHP
PHP解析url并得到url参数方法总结
Oct 11 #PHP
详细对比php中类继承和接口继承
Oct 11 #PHP
PHP JWT初识及其简单示例
Oct 10 #PHP
php-fpm.conf配置文件中文说明详解及重要参数说明
Oct 10 #PHP
php实现单笔转账到支付宝功能
Oct 09 #PHP
php实现小程序支付完整版
Oct 09 #PHP
php实现微信企业付款到个人零钱功能
Oct 09 #PHP
You might like
php 无限级缓存的类的扩展
2009/03/16 PHP
PHP SEO优化之URL优化方法
2011/04/21 PHP
将word转化为swf 如同百度文库般阅读实现思路及代码
2013/08/09 PHP
php实现telnet功能示例
2014/04/08 PHP
php数组随机排序实现方法
2015/06/13 PHP
PHP生成唯一订单号
2015/07/05 PHP
php简单解析mysqli查询结果的方法(2种方法)
2016/06/29 PHP
js innerHTML 的一些问题的解决方法
2008/06/22 Javascript
跟着Jquery API学Jquery之一 选择器
2010/04/07 Javascript
jQuery代码优化之基本事件
2011/11/01 Javascript
javascript 进阶篇1 正则表达式,cookie管理,userData
2012/03/14 Javascript
NodeJS与Mysql的交互示例代码
2013/08/18 NodeJs
js字符串转换成数字与数字转换成字符串的实现方法
2014/01/08 Javascript
浅谈页面装载js及性能分析方法
2014/12/09 Javascript
jQuery中first()方法用法实例
2015/01/06 Javascript
js print打印网页指定区域内容的简单实例
2016/11/01 Javascript
jquery实现折叠菜单效果【推荐】
2017/03/08 Javascript
微信小程序提交form操作示例
2018/12/30 Javascript
JavaScript函数式编程(Functional Programming)高阶函数(Higher order functions)用法分析
2019/05/22 Javascript
vue中提示$index is not defined错误的解决方式
2020/09/02 Javascript
[36:13]Mineski vs iG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python中使用wxPython开发的一个简易笔记本程序实例
2015/02/08 Python
Python中index()和seek()的用法(详解)
2017/04/27 Python
python 处理微信对账单数据的实例代码
2019/07/19 Python
Python3实现二叉树的最大深度
2019/09/30 Python
Pytorch模型转onnx模型实例
2020/01/15 Python
详解HTML5布局和HTML5标签
2020/10/26 HTML / CSS
美国性感内衣店:Yandy
2018/06/12 全球购物
英国领先的名牌服装折扣零售商:Brown Bag Clothing
2019/01/08 全球购物
高中毕业生个人自我鉴定
2013/11/24 职场文书
新年抽奖获奖感言
2014/03/02 职场文书
中队活动总结
2014/08/27 职场文书
2014年采购员工作总结
2014/11/18 职场文书
授权委托书
2015/01/28 职场文书
银行先进个人总结
2015/02/15 职场文书
mysql升级到5.7时,wordpress导数据报错1067的问题
2021/05/27 MySQL