thinkphp 和 Gatewayworker整合web聊天

第一步:下载tp3.2.3、GatewayWorker、GatewayClient;

解压后把tp和Gatewayworker放在同一个目录下面(根目录下面);

第二步:将GatewayClient中的Gateway.php重命名为Gateway.class.php;

修改其内容如下:
1.namespace Org\Util;
2.第35行的$registerAddress的端口号修改和GatewayWorker/Application/YourApp/下的三个start_文件里面的“服务注册地址”下端口号一致;
保存后将该文件放于tp框架的ThinkPHP/Library/Org/Util文件夹下;

第三步:将GatewayWorker中start_gateway.php的第24行Gateway括号内容修改为(“websocket://后面的不变”);

Events.php的第40行修改为Gateway::sendToClient($client_id,json_encode(array('client_id'=>$client_id)));可注释第42行代码;

第四步:运行tp入口文件后,控制器Index.class.php文件内容如下:

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
    // public $uid = 2;
    public function index() {
        // $this->uid = I('uid');
        session('uid', $this->uid);
        $this->display();
    } 

    function bind() { 
        $uid = session('uid');
        $client_id = I('client_id');
        $gateway = new \Org\Util\Gateway();
        $gateway->bindUid($client_id, $uid);
        $message = '绑定成功' . $uid . '-' . $client_id;
        $gateway->sendToUid($uid, $message);
    } 

    function message() { 
        $to_uid = I('uid');
        $message = I('msg');
        $gateway = new \Org\Util\Gateway();
        $data['msg'] = $message;
        $data['from_uid'] = session('uid');
        $data['to_uid'] = $to_uid;
        $gateway->sendToUid($to_uid, json_encode($data));
        //发给对方 
        $gateway->sendToUid($data['from_uid'], json_encode($data));
        //发给自己 
        echo json_encode($data);
    }
}

视图文件index.html文件内容为:(其他文件自己建,不贴了)

<!DOCTYPE html>
<html>
<head> 
<meta charset="utf-8" /> 
<title>chatroom</title> 
<script type="text/javascript" src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script> 
<script type="text/javascript"> 
// 打开一个 web socket 
var ws = new WebSocket("ws://127.0.0.1:8282");
ws.onopen = function() {};
ws.onmessage = function(evt) {
    var received_msg = evt.data;
    console.log(received_msg);
    // alert("数据已接收..." + received_msg);
    var jmsg = JSON.parse(received_msg);
    if (jmsg.from_uid > 0) {
        var t_msg = '<li>' + jmsg.from_uid + ' 说:' + jmsg.msg + '</li>';
        $("#message").append(t_msg);
    }
    if (jmsg.client_id.length != 0) {
        $.post("{:U('Index/bind')}", {
            client_id: jmsg.client_id
        },
        function(data) {
            console.log(data);
        });
    }
} 
</script> 
</head> 
<body> 
<ul id="message"> 
</ul>

<div> 
    <input name="uid" value="1" /> 
    <input name="msg" value="" size="50" /> 
    <button type="button" id="send">发送</button> 
</div> 

<script>
$(function() {
    $("#send").click(function() {
        var uid = $('input[name="uid"]').val();
        var msg = $('input[name="msg"]').val();
        $.post("{:U('Index/message')}", {
            uid: uid,
            msg: msg
        },
        function(data) {
            $('input[name="msg"]').val('');
        });
    });
});
</script>  
</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容

  • 继续上篇文章(链接),把功能添加到项目里面项目使用thinkphp3.2.3开发现在主要做手机端功能,页面也是手机...
    f09037cb27f7阅读 886评论 2 7
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,639评论 18 139
  • 因为最近有个项目涉及到Socket通信,于是自己尝试了一下搭建一个服务端WebSocket通信的项目,写个笔记,能...
    全栈工程师wql阅读 956评论 0 0
  • 说实话,我一直在犹豫是否该写下这段文字。写下,或多或少会让自己觉得有些难堪;不写,却又会因为这样的心境不记录下来显...
    Niki哥阅读 540评论 0 1
  • 小区楼内有一老妇,年六十有余,状其老态,眼神迷离,爱拉人讲话,且一说就无尾,不够不休。原交流极少,只是见面点点头,...
    郭晓光阅读 313评论 0 3