使用PHP+Swoole实现的网页即时聊天工具

  • 全异步非阻塞Server,可以同时支持数百万TCP连接在线

  • 同时支持websocket+comet2种兼容协议,可用于所有种类的浏览器包括IE

  • 拥有完整的UI界面

  • 支持单聊/群聊/组聊等功能

  • 支持发送表情

  • 支持永久保存聊天记录

  • 基于Server PUSH的即时内容更新,登录/登出/状态变更/消息等会内容即时更新

    最新的版本已经可以原生支持IE系列浏览器了,基于Http长连接

    安装

    swoole扩展

    1. pecl install swoole

    swoole框架

    1. composer install

    运行

    将client目录配置到Nginx/Apache的虚拟主机目录中,使client/index.html可访问。修改client/config.js中,IP和端口为对应的配置。

    1. php webim_server.php

    详细部署说明

    1.安装composer(php依赖包工具)

    1. curl -sS https://getcomposer.org/installer | php
    2. mv composer.phar /usr/local/bin/composer

    注意:如果未将php解释器程序设置为环境变量PATH中,需要设置。因为composer文件第一行为#!/usr/bin/env php,并不能修改。更加详细的对composer说明:http://blog.csdn.net/zzulp/article/details/18981029

    2.composer install

    切换到PHPWebIM项目目录,执行指令composer install,如很慢则

    1. composer install --prefer-dist

    3.Ningx/Apache配置(这里未使用swoole_framework提供的Web AppServer)

    nginx

    1. server
    2. {
    3. listen 80;
    4. server_name im.swoole.com;
    5. index index.shtml index.html index.htm index.php;
    6. root /path/to/PHPWebIM/client;
    7. location ~ .*\.(php|php5)?$
    8. {
    9. fastcgi_pass 127.0.0.1:9000;
    10. fastcgi_index index.php;
    11. include fastcgi.conf;
    12. }
    13. access_log /Library/WebServer/nginx/logs/im.swoole.com access;
    14. }

    apache

    1. <VirtualHost *:80>
    2. DocumentRoot "path/to/PHPWebIM/client"
    3. ServerName im.swoole.com
    4. AddType application/x-httpd-php .php
    5. <Directory />
    6. Options Indexes FollowSymLinks
    7. AllowOverride None
    8. Require all granted
    9. DirectoryIndex index.php
    10. </Directory>
    11. </VirtualHost>

    4.修改配置PHPWebIM/config.php

    1. $config['server'] = array(
    2. //监听的HOST
    3. 'host' => '0.0.0.0',
    4. //监听的端口
    5. 'port' => '9503',
    6. //WebSocket的URL地址,供浏览器使用的
    7. 'url' => 'ws://127.0.0.1:9503',
    8. );
    • server.host server.port 项为WebIM服务器即WebSocket服务器的IP与端口,其他选择项根据具体情况修改
    • server.url对应的就是服务器IP或域名以及websocket服务的端口,这个就是提供给浏览器的WebSocket地址
    • webim.data_dir用于修改聊天记录存储的目录,必须有可写权限

    5.启动WebSocket服务器

    1. php PHPWebIM/webim_server.php

    IE浏览器不支持WebSocket,需要使用FlashWebSocket模拟,请修改flash_policy.php中对应的端口,然后启动flash_policy.php。

    1. php PHPWebIM/flash_policy.php

    6.绑定host与访问聊天窗口(可选)

    如果URL直接使用IP:PORT,这里不需要设置。

    1. vi /etc/hosts

    增加

    1. 127.0.0.1 im.swoole.com

    用浏览器打开:http://im.swoole.com

    快速了解项目架构

    1.目录结构

    1. + PHPWebIM
    2. |- webim_server.php //WebSocket协议服务器
    3. |- config.php // swoole运行配置
    4. |+ swoole.ini // WebSocket协议实现配置
    5. |+ client
    6. |+ static
    7. |- config.js // WebSocket client配置
    8. |- index.html // 登录界面
    9. |- main.html // 聊天室主界面
    10. |+ data // 运行数据
    11. |+ log // swoole日志及WebIM日志
    12. |+ src // WebIM 类文件储存目录
    13. |+ Store
    14. |- File.php // 默认用内存tmpfs文件系统(linux /dev/shm)存放天着数据,如果不是linux请手动修改$shm_dir
    15. |- Redis.php // 将聊天数据存放到Redis
    16. |- Server.php // 继承实现WebSocket的类,完成某些业务功能
    17. |+ vendor // 依赖包目录

    2.Socket Server与Socket Client通信数据格式

    如:登录

    Client发送数据

    1. {"cmd":"login","name":"xdy","avatar":"http://tp3.sinaimg.cn/1586005914/50/5649388281/1"}

    Server响应登录

    1. {"cmd":"login", "fd": "31", "name":"xdy","avatar":"http://tp3.sinaimg.cn/1586005914/50/5649388281/1"}

    可以看到cmd属性,client与server发送时数据都有指定,主要是用于client或者server的回调处理函数。

    3.需要理清的几种协议或者服务的关系

    http协议:超文本传输协议。单工通信,等着客户端请求之后响应。

    WebSocket协议:是HTML5一种新的协议,它是实现了浏览器与服务器全双工通信。服务器端口与客户端都可以推拉数据。

    Web服务器:此项目中可以用基于Swoole的App Server充当Web服务器,也可以用传统的nginx/apache作为web服务器

    Socket服务器:此项目中浏览器的WebSocket客户端连接的服务器,swoole_framework中有实现WebSocket协议PHP版本的服务器。

    WebSocket Client:实现html5的浏览器都支持WebSocket对象,如不支持此项目中有提供flash版本的实现。

项目主页:http://www.open-open.com/lib/view/home/1416465136852

使用PHP+Swoole实现的网页即时聊天工具:PHPWebIM的更多相关文章

  1. 基于Nodejs开发的web即时聊天工具

    由于公司需要开发web即时聊天的功能,开始时我们主要的实施方法是用jquery的ajax定时(10秒)轮询向服务器请求,由于是轮询请求,对 服务器的压力比较大.我们网站上线的时间不长,访问量不是很大, ...

  2. 仿微信 即时聊天工具 - SignalR (一)

    话不多说,先上图 背景: 微信聊天,经常会遇见视频发不了,嗯,还有聊天不方便的问题,于是我就自己买了服务器,部署了一套可以直接在微信打开的网页进行聊天,这样只需要发送个url给朋友,就能聊天了! 由于 ...

  3. Pilin —— 一个基于Xmpp openfire smack的即时聊天工具

    https://github.com/whfcomm/Pilin

  4. Node.js + Web Socket 打造即时聊天程序嗨聊

    前端一直是一块充满惊喜的土地,不仅是那些富有创造性的页面,还有那些惊赞的效果及不断推出的新技术.像node.js这样的后端开拓者直接将前端人员的能力扩大到了后端.瞬间就有了一统天下的感觉,来往穿梭于前 ...

  5. 几款web版整合(QQ、msn、icq、yahoo通、Gtalk等)即时聊天http://hi.baidu.com/ejie/blog/item/e89794ef9a9431efce1b3ebd.html

        直到近期为止,我们经常使用的即时聊天工具(QQ.msn等)了Web版,大家不用下载庞大软件,直接打开网页就能够与自己的好友聊天,很方便.在此将时汇总,便于大家查找,节约大家一点时间. 此都是官 ...

  6. Web版的各种聊天工具

    直到近期为止,我们经常使用的即时聊天工具(QQ.msn等)了Web版,大家不用下载庞大软件,直接打开网页就能够与自己的好友聊天,非常方便.在此将时汇总        便于大家查找        节约大 ...

  7. tomcat websocket 实现网页在线即时聊天

    背景介绍 近一个月完成了公司的一个项目,负责即时聊天部分 寻找了一下,决定使用websocket,要问原因的话,因为tomcat 自带相关消息收发的API,用起来方便 闲话少叙,进入实现步骤 使用工具 ...

  8. SignalR快速入门 ~ 仿QQ即时聊天,消息推送,单聊,群聊,多群公聊(基础=》提升)

     SignalR快速入门 ~ 仿QQ即时聊天,消息推送,单聊,群聊,多群公聊(基础=>提升,5个Demo贯彻全篇,感兴趣的玩才是真的学) 官方demo:http://www.asp.net/si ...

  9. golang从简单的即时聊天来看架构演变

    前言 俗话说的好,架构从来都不是一蹴而就的,没有什么架构一开始设计就是最终版本,其中需要经过很多步骤的变化,今天我们就从一个最简单的例子来看看,究竟架构这个东西是怎么变的. 我将从一个最简单的聊天室的 ...

随机推荐

  1. JS 插件 fastclick.js 解决手机端click点击延迟

    FastClick 是一个简单,易于使用的JS库用于消除在移动浏览器上触发click事件与一个物理Tap(敲击)之间的300延迟. 对于非移动浏览器不启作用,禁用缩放标签. <meta name ...

  2. c语言复制文件程序

    #include <stdio.h> #include <stdlib.h> #include <string.h> #define SIZE 1024*1024* ...

  3. 001-centos7安装 笔记本 联想G510

    一.准备前提 1.联想G510AT 用winpe进入笔记本电脑,找到一个分区,删除即可 2.使用U盘安装 2.1.准备一个8G 的U盘,格式化ntfs. 2.2.在window下,下载UltraISO ...

  4. python ipython notebook或者 jupyter notebook 的安装

    IPython Notebook使用浏览器作为界面,向后台的IPython服务器发送请求,并显示结果.在浏览器的界面中使用单元(Cell)保存各种信息.Cell有多种类型,经常使用的有表示格式化文本的 ...

  5. JavaScript setInterval()執行clearInterval() 再恢復setInterval()

    clearInterval() 方法可取消由 setInterval() 设置的 timeout. clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值. ...

  6. uwsgi+nginx项目上线

    一.基础环境配置 1.Linux安装配置     1.设置IP地址 [root@localhost ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0 ...

  7. django-admin引用百度地图

    实现的功能有,某个地点对应的经纬度自动填上,如果有经纬度的话,自动显示对应经纬度的地点,密匙在去百度地图引用搜索 <script type="text/javascript" ...

  8. 【整理学习Hadoop】Hadoop学习基础之二:分布式

      分布式系统就是将系统的应用层,数据层或其它部分构架成分布(物理和逻辑上的都可以)状(通常是网状).分布式系统通常是为了增强系统的可扩展性.稳定性和执行效率.比如在线游戏通常就是分布系统,里面所谓的 ...

  9. java中byte数组与int,long,short间的转换

    http://blog.csdn.net/leetcworks/article/details/7390731 package com.util; /** * * <ul> * <l ...

  10. HDF及HDF-EOS数据格式简介

    HDF-EOS数据格式介绍 HDF(Hierarchy Data Format )数据格式是美国伊利诺伊大学国家超级计算应用中心(NCSA ,National Central for Super co ...