全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

WebSocket实现简单客服聊天系统

一 需求

一个多商家的电商系统,比如京东商城,不同商家之间的客服是不同的,所面对的用户也是不同的。要实现这样一个电商系统的客服聊天系统,那该系统就必须是一个支持多客服、客服一对多用户的聊天系统。

二 思路

使用 Node.js 搭建服务器,安装 websocket 模块、node-uuid模块。通过在客服端和用户端传递 客服ID 和 用户ID 来进行消息的传送。

三 具体实现

3.1 搭建 Node 服务器

参考本人前面的文章 《Centos6.8 下 Node.js 的安装》。

3.2 安装 ws 模块、node-uuid 模块

npm install ws
npm install ws

3.3 创建 server.js

在项目里面新建一个server.js,创建服务,指定8906端口(下面是主要代码,仅供参考)

const WebSocket = require('ws');
onst wss = new WebSocket.Server({ port: 8906 });
const uuid = require('node-uuid');
// 省略一些参数的定义
// 服务端处理连接
wss.on('connection', function(ws) {
  console.log('client [%s] connected', clientIndex);
  var connection_uuid = uuid.v4();
  var nickname = "AnonymousUser" + clientIndex;
  clientIndex += 1;
  clients.push({ "id": connection_uuid, "ws": ws, "nickname": nickname });
  
 //服务器收到消息时
  ws.on('message', function(e) {
   var data = JSON.parse(e);
   var type = data.type;
   // 省略业务处理逻辑
  });

  // ws连接关闭时触发的操作
  ws.on("close", function () {
   websocketClose();
  });
  
  // 省略函数 websocketClose()、wsSend()、socketClose 的定义
  // 服务器关闭所触发的操作
  process.on("SIGINT", function () {
   console.log("SOCKET CLOSED!");
   ("客服已关闭,请稍后再来");
   process.exit();
  });
});

3.4 创建 customer.html

该页面是用户页面。在页面上建立一个WebSocket的连接,并实现向服务器端发送消息(下面是主要代码,仅供参考)

<script>
  //建立连接
  const ws = new WebSocket("ws://22.33.66.88:8906");
  var client_id = '';
  
  //ws连接打开后的操作
  ws.onopen = function (e) {
   //向服务器发送该ws连接的用户信息
  };

  //收到消息处理
  ws.onmessage = function (e) {
   // 省略
  };
   
  //ws连接出错所触发的操作
  ws.onerror = function (e) {
   // 省略
  };

  //ws连接关闭时所触发的操作
  ws.onclose = function (e) {
   // 省略
  };
   
  // 省略函数 appendLog()、sendMessage()、sendMessage2()、wsSendMessage() 的定义
</script>

 3.5 创建 customerService.html

该页面是客服页面,类似于 customer.html,代码方面可参考 customer.html

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# WebSocket客服聊天系统  # WebSocket聊天系统  # WebSocket客服系统  # 客服  # 仅供参考  # 是一个  # 再来  # 这样一个  # 建立一个  # 类似于  # 多用户  # 服务端  # 大家多多  # 新建一个  # 那该  # 请稍后  # 发送消息  # 京东  # 就必须  # require  # WebSocket  # const  # connected 


相关文章: 微信小程序 五星评分(包括半颗星评分)实例代码  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何解决VPS建站LNMP环境配置常见问题?  建站与域名管理如何高效结合?  微信推文制作网站有哪些,怎么做微信推文,急?  建站之星后台管理系统如何操作?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  详解jQuery停止动画——stop()方法的使用  网站专业制作公司有哪些,做一个公司网站要多少钱?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  在线制作视频网站免费,都有哪些好的动漫网站?  导航网站建站方案与优化指南:一站式高效搭建技巧解析  Swift中switch语句区间和元组模式匹配  官网网站制作腾讯审核要多久,联想路由器newifi官网  如何高效利用200m空间完成建站?  定制建站流程步骤详解:一站式方案设计与开发指南  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  如何在Windows服务器上快速搭建网站?  html制作网站的步骤有哪些,iapp如何添加网页?  建站之星安装步骤有哪些常见问题?  建站之星安装失败:服务器环境不兼容?  如何在阿里云部署织梦网站?  制作门户网站的参考文献在哪,小说网站怎么建立?  宝塔新建站点为何无法访问?如何排查?  建站之星如何快速解决建站难题?  PHP 500报错的快速解决方法  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  建站主机核心功能解析:服务器选择与网站搭建流程指南  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  网站制作难吗安全吗,做一个网站需要多久时间?  如何在景安云服务器上绑定域名并配置虚拟主机?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  建站之星CMS建站配置指南:模板选择与SEO优化技巧  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  微课制作网站有哪些,微课网怎么进?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  如何选择最佳自助建站系统?快速指南解析优劣  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  TestNG的testng.xml配置文件怎么写  C#怎么创建控制台应用 C# Console App项目创建方法  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  C#如何使用XPathNavigator高效查询XML  南宁网站建设制作定制,南宁网站建设可以定制吗?  常州自助建站费用包含哪些项目?  网站制作新手教程,新手建设一个网站需要注意些什么?  ,网站推广常用方法?  小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建    如何用PHP快速搭建高效网站?分步指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。