共享网页聊天室的设计与实现

194806_5FmV_2660780.gif

系统概述

技术结构

webpack

本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle

在该例中,我们用其编译和合并压缩 ES5 以上 JS、SASS/SCSS、各种图片和字体资源等,并建立开发模式下热重载服务端,以方便系统调试。

jQuery

jQuery 是一个“写的更少,但做的更多”的轻量级 JavaScript 库。

在该例中,我们用其操作 DOM 节点。

WebSocket

WebSocket 是基于TCP的一种新的网络协议,不同于 HTTP 一次请求一次响应的机制,它允许服务器主动发送信息给客户端,由此衍生了许多基于 WebSocket 的 web 即时应用。

在该例中,我们采用 node 第三方 ws 模块以建立网页即时通讯服务端。

核心功能

  • 当打开页面时,系统会为用户随机分配一个名称

  • 用户可以手动修改名称,系统将向所有客户端广播消息以同步数据

  • 当用户 建立/关闭 连接时,系统将广播消息通知所有客户端创建新的联系人项目

  • 用户可以向所有参与者或指定参与者发送消息

原型设计

原型图

184830_Z0St_2660780.png

process on 链接地址

 

流程设计

流程图

185643_WtKi_2660780.png

process on 链接地址

流程描述

打开页面

194638_bZoB_2660780.gif

  1. 打开页面时,客户端为用户分配随机用户名,并向服务端发送 open 消息

    // 消息格式
    {
      type: 'open',
      payload: {
        name
      }
    }
  2. 服务端接收 open 消息,转发至服务端 Mediator

  3. Mediator 根据 contactCounter 生成客户端 id 号,并新增 contact 对象,之后进入回调流程 4、5

  4. 服务端向新建连接的客户端发送 load 消息,之后进入流程 6

    // 消息格式
    {
      type: 'load',
      payload: {
        from: {id, name},
        contactList: mediator.contactList(), // 联系人列表
        talkHistory: mediator.talkHistory().filter(item => item.to.id === 0) // 聊天记录中群发的消息
      }
    }
  5. 服务端向原有客户端发送 contact 消息,之后进入流程 7

    // 消息格式
    {
      type: 'contact',
      payload: {
        id, name
      }
    }
  6. 新建连接的客户端接收 load 消息,转发至 Mediator,初始化联系人列表和聊天历史记录并渲染 UI

  7. 原有客户端接收 contact 消息,转发至 Mediator,新增联系人列表项并渲染 UI

发送消息

194806_5FmV_2660780.gif

  1. 用户输入并发送信息,客户端向服务端发送 message 消息

    // 消息格式
    {
      type: 'message',
      payload: {
        from: {id,name},
        to: {id,name},
        msg,
        timestamp
      }
    }
  2. 服务端接收 message 消息,转发至服务端 Mediator

  3. Mediator 根据 talkCounter 生成聊天记录 id 号,并新增聊天记录,之后进入回调流程 4

  4. 服务端向目标客户端发送 message 消息,消息格式同流程 1

  5. 客户端接收 message 消息,转发至客户端 Mediator

  6. 客户端 Mediator 新增聊天记录项并渲染 UI

修改用户名

194811_QlW5_2660780.gif

  1. 用户修改用户名时,客户端向服务端发送 nickname 消息

    // 消息格式
    {
        type: 'nickname',
        payload: {
          id: targetId,
          name: modifiedName
        }
    }
  2. 服务端接收 nickname 消息,转发至服务端 Mediator

  3. Mediator 修改目标用户的信息和与之相关的所有聊天历史记录,之后进入回调流程 4

  4. 服务端向所有建立连接的客户端发送 reload 消息

    // 消息格式
    {
      type: 'reload',
      payload: {
        contactList: mediator.contactList(), // 联系人列表
        talkHistory: mediator.talkHistory().filter(record => { // 过滤和当前 client 有关的聊天记录
          return record.from.id === client.id || record.to.id === client.id || record.to.id === 0
        })
      }
    }
  5. 客户端接收 reload 消息,转发至客户端 Mediator

  6. 客户端 Mediator 更新联系人列表和聊天历史记录并渲染 UI

关闭页面

194652_BafM_2660780.gif

  1. 关闭页面时,服务端捕获 close 事件并向所有客户端发送 lose 消息

    // 消息格式
    {
      type: 'lose',
      payload: {
        id
      }
    }
  2. 客户端接收 lose 消息,转发至客户端 Mediator

  3. Mediator 移除联系人列表项并渲染 UI

补充说明

  • 系统只建立一个共享聊天室,其中 WebSocket Server 服务于所有 Client 端。

  • 系统不以任何方式留存用户信息,打开页面即视为新的客户端建立连接,关闭页面即视为客户端永久断开连接。

  • 兼容 Chrome, Firefox, Sogou 浏览器,不兼容 IE

源码下载

GitHub

转载于:https://my.oschina.net/lonelydawn/blog/1217736

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值