一 需求

一个多商家的电商系统,比如京东商城,不同商家之间的客服是不同的,所面对的用户也是不同的。要实现这样一个电商系统的客服聊天系统,那该系统就必须是一个支持多客服、客服一对多用户的聊天系统。
二 思路
使用 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小时内与您取得联系。