Workerman之GatewayWorker框架 - 在线客服,实时通信

一、绑定用户id实现一对一客服聊天

相关文档:LibGateway类提供的接口

JS:

Workerman之GatewayWorker框架 - 在线客服,实时通信_第1张图片

/**
     * 当客户端连接时触发
     * 如果业务不需此回调可以删除onConnect
     * 
     * @param int $client_id 连接id
     */
    public static function onConnect($client_id)
    {
        global $num;
        // 向当前client_id发送数据
        //Gateway::sendToClient($client_id, "Hello $client_id\r\n");
        // 向所有人发送
       // Gateway::sendToAll("$client_id login\r\n");

        echo "connect".++$num.":".$client_id."\n";

        Gateway::sendToClient($client_id,json_encode([
           'type'=>'init',
           'client_id'=>$client_id
       ]));

    }
    
   /**
    * 当客户端发来消息时触发
    * @param int $client_id 连接id
    * @param mixed $message 具体消息
    */
   public static function onMessage($client_id, $message)
   {
       $message_data = json_decode($message,true);
       if(!$message_data){
           return;
       }
       switch($message_data['type']){
           case "bind":
               $fromid = $message_data['fromid'];
               Gateway::bindUid($client_id, $fromid);
               return;
           case "say":

               $text = nl2br(htmlspecialchars($message_data['data']));
               $fromid = $message_data['fromid'];
               $toid = $message_data['toid'];

               $date=[
                   'type'=>'text',
                   'data'=>$text,
                   'fromid'=>$fromid,
                   'toid'=>$toid,
                   'time'=>time()
               ];
                Gateway::sendToUid($toid, json_encode($date));
//               Gateway::sendToAll(json_encode($date));
               return;
       }
   }

Test:

Workerman之GatewayWorker框架 - 在线客服,实时通信_第2张图片

Workerman之GatewayWorker框架 - 在线客服,实时通信_第3张图片

二、数据持久化与优化两个聊天对象的唯一性

   public static function onMessage($client_id, $message)
   {
       $message_data = json_decode($message,true);
       if(!$message_data){
           return;
       }
       switch($message_data['type']){
           case "bind":
               $fromid = $message_data['fromid'];
               Gateway::bindUid($client_id, $fromid);
               return;
           case "say":
               $text = nl2br(htmlspecialchars($message_data['data']));
               $fromid = $message_data['fromid'];
               $toid = $message_data['toid'];

               $date=[
                   'type'=>'text',
                   'data'=>$text,
                   'fromid'=>$fromid,
                   'toid'=>$toid,
                   'time'=>time()
               ];

               if(Gateway::isUidOnline($toid)){
                   Gateway::sendToUid($toid, json_encode($date));
                   $date['isread']= 1;
               }else{
                   $date['isread']=0;
               }

               $date['type']="save";
               Gateway::sendToUid($fromid,json_encode($date));

               return;
       }
   }
ws.onmessage = function(e){

       var message =  eval("("+e.data+")");
          switch (message.type){
              case "init":
                   var bild = '{"type":"bind","fromid":"'+fromid+'"}';
                   ws.send(bild);

                  return;
              case "text":
                  //指定两个聊天对象聊天
                      if(toid==message.fromid) {

                          $(".chat-content").append(' 
' + message.data + '
'); } return; case "save": //数据持久化 save_message(message); return; } }

三、发图片、QQ表情、聊天列表、所有页面websocket,消息推送、实时更新

Workerman之GatewayWorker框架 - 在线客服,实时通信_第4张图片

Workerman之GatewayWorker框架 - 在线客服,实时通信_第5张图片

Workerman之GatewayWorker框架 - 在线客服,实时通信_第6张图片

相关代码:https://github.com/tcyfree/ch...

参考教程:workerman实战之PHP在线客服

你可能感兴趣的:(workerman,gateway,websocket,即时通讯)