服务端:

<?php
class Chat
{
const HOST = '0.0.0.0';//ip地址 0.0.0.0代表接受所有ip的访问
const PART = 8080;//端口号 private $server = null;//单例存放websocket_server对象 public $roles = [
'郭靖','杨过','洪七公','尹志平','赵志敬','丘处机','欧阳锋','一灯大师','黄药师'
]; public function __construct()
{
//实例化swoole_websocket_server并存储在我们Chat类中的属性上,达到单例的设计
$this->server = new swoole_websocket_server(self::HOST, self::PART);
//监听连接事件
$this->server->on('open', [$this, 'onOpen']);
//监听接收消息事件
$this->server->on('message', [$this, 'onMessage']);
//监听关闭事件
$this->server->on('close', [$this, 'onClose']);
//设置允许访问静态文件
$this->server->set([
'document_root' => '/www/chat1',//这里传入静态文件的目录
'enable_static_handler' => true//允许访问静态文件
]); //开启服务
$this->server->start();
} /**
* 连接成功回调函数
* @param $server
* @param $request
*/
public function onOpen($server, $request)
{
echo $request->fd . '连接了' . PHP_EOL;//打印到我们终端
$server->push($request->fd,json_encode(['no' => $request->fd, 'msg' =>'']));
} /**
* 接收到信息的回调函数
* @param $server
* @param $frame
*/
public function onMessage($server, $frame)
{
$role = $this->getRole($frame->fd);
echo $role. '来了,说:' . $frame->data . PHP_EOL;//打印到我们终端
foreach ($server->connections as $fd) {//遍历TCP连接迭代器,拿到每个在线的客户端id
//将客户端发来的消息,推送给所有用户,也可以叫广播给所有在线客户端
$msg = $frame->data;
$server->push($fd, json_encode(['no' => $frame->fd,'role'=>$role, 'msg' => $msg]));
}
} public function getRole($fd)
{
$roles = count($this->roles);
$role = ($fd < $roles) ? $this->roles[$fd] : $this->roles[$fd%$roles];
var_dump($role);
return $role;
} /**
* 断开连接回调函数
* @param $server
* @param $fd
*/
public function onClose($server, $fd)
{
echo $fd . '走了' . PHP_EOL;//打印到我们终端
} } $obj = new Chat();

  客户端

<!doctype html>

<html>

<head>

    <meta charset="utf-8">

    <title>聊天室</title>

    <script src="http://libs.baidu.com/jquery/1.9.1/jquery.min.js"></script>

</head>

<body>
<style>
.right {
color: blue;
display:block;
float:right;
width:100%;
} </style> <div style="width: 500px; margin:0 auto;">
<div class="log" id='scrolldIV' style="height:500px;border: 2px solid #ccc;line-height: 1.5em;overflow:auto" >

=======聊天室====== </div> <!--<input type="button" value="连接" onClick="link()">-->
<input type="hidden" value="" id="fd">
<!--<input type="button" value="断开" onClick="dis()">--> <div >
<input type="text" id="text"> <input type="button" value="发送" onClick="send()" id="submit">
</div> </div> <script> $(document).keydown(function(event){
if(event.keyCode==13){
$("#submit").click();
}
}); $(function () {
$("#text").focus();
link();
}) function link() { var url = 'ws://192.168.33.60:8080'; socket = new WebSocket(url); socket.onopen = function (evt) {
log1('<div>连接成功</div>')
} socket.onmessage = function (msg) {
var data = $.parseJSON(msg.data)
if(data.msg.length <= 0){
$("#fd").val(data.no);
} else {
log(data);
}
      
     
        var div = document.getElementById('scrolldIV');
        div.scrollTop = div.scrollHeight;
        }

        socket.onclose = function () {
log1('<div>断开连接</div>')
} } function dis() { socket.close(); socket = null; } function log1(data) {
$('.log').append(data);
}
function log(data) {
var nowFd = $("#fd").val();
console.log(data);
var role;
if(data['no'] == nowFd){
role ="我";
$('.log').append("<div class='right'>" + role+":"+ data['msg'] + '</div>');
} else { $('.log').append("<div >" + data.role+": "+data['msg'] + '</div>');
} } function send() {
var text = $('#text').val();
if(text.length > 0){
socket.send(text);
$("#text").val('');
} $("#text").focus(); } function send2() { var json = JSON.stringify({'type': 'php', 'msg': $('#text2').attr('value')}) socket.send(json); } </script> </body> </html>

  

服务端 启动

php Chat.php

访问客户端的html 浏览器打开

参考 https://www.jianshu.com/p/ac77f05bee56

最新文章

  1. iOS开发——网络篇——JSON和XML,NSJSONSerialization ,NSXMLParser(XML解析器),NSXMLParserDelegate,MJExtension (字典转模型),GDataXML(三方框架解析XML)
  2. AX Dynamics 去中文字符长度:中文字符当2个字符处理
  3. CUDA学习笔记(四)——CUDA性能
  4. 《Java程序性能优化》学习笔记 JVM和并发优化
  5. .NET环境配置(二)
  6. yii2.0 gii
  7. Perl 内部结构详解
  8. go的优缺点
  9. J - 计算两点间的距离
  10. 顺序栈和链式栈(C++实现)
  11. ORACLE 本地冷迁移
  12. 【一天一道LeetCode】#326. Power of Three
  13. 衡量android开发者水平的面试问题-android学习之旅(91)
  14. bzoj1452
  15. Docker修改默认网段
  16. 【APUE | 7】命令形参、函数
  17. 数据结构与算法--最短路径之Floyd算法
  18. iOS 10 的一个重要更新-用 UIViewPropertyAnimator 编写动画
  19. keepalived的log
  20. webpack 编译ES6插件babel-loader

热门文章

  1. mariadb升级
  2. (一)java面试易忘题目精选(1)
  3. MySQL必知必会:组合查询(Union)
  4. 【Leetcode_easy】788. Rotated Digits
  5. 已经安装了VRay但3dmax的材质编辑器里没有VRay材质的解决过程
  6. 最新 盛天网络java校招面经 (含整理过的面试题大全)
  7. ORACLE创建表空间和用户,并分配权限
  8. Memcached内存调优及建议
  9. 初始mysql
  10. storm是如何保证at least once语义的?