您当前的位置:首页 > 电脑百科 > 程序开发 > 架构

网页聊天客服是如何制作的?使用WebSocket技术!

时间:2020-03-16 10:38:01  来源:  作者:

大家看看华为商城的客服系统,有没有想过到底是如何制作出来的。你和客服MM的一问一答到底是如何实现的?学过ajax的朋友肯定知道,可以使用轮询方式,隔一秒到服务器里面去查询是否有聊天信息的到来,如果有,就取出来。这样肯定是可以的。但是这样做服务器压力实在太大。如果有很多人在聊天呢?服务器可能受不了,所以,我们今天来使用WebSocket技术。该技术的特别之处在于,与HTTP协议最大的不同是,HTTP协议需要请求一次,响应一次。而WebSocket使用的是协议是,一次握手,时时通讯。意思就是,第一次采用http协议握手完成之后,后面的链接就一直会保持,服务器也可以向客户端发送信息。而不再是单向的通讯方式了。

 

网页聊天客服是如何制作的?使用WebSocket技术!

华为客服系统

当然,制作这个客服聊天系统确实不容易,但是如果我们只想做个简单的网页聊天那还是没有问题的。

接下来,我给大家贴出一些关键代码,给大家演示如何开发出一个网页聊天系统。

必备技能:

htmlcssJAVAScript,java,javaWeb,Tomcat服务器,数据库MySQL

1 首页,必须写一个登陆页面,如果没有登录功能,那么网页对方就不知道你的身份了。大部分情况都是需要登录的。当然如果不登录,也是可以的,系统可以给你指定一个称呼,目前大多数客服系统都是 有登录的。

 

网页聊天客服是如何制作的?使用WebSocket技术!

登录代码

 

网页聊天客服是如何制作的?使用WebSocket技术!

登录界面

登录使用的是jquery的ajax向servlet发送请求,servlet调用数据库dao查询是否存在账号。这个步骤如果不会的话,那需要将JavaScript和javaWeb学习一遍。

2 写一个聊天的界面,这个界面代码较多,但是大家可以去各种素材网站找模板,不用自己写的,copy就行了。

 

网页聊天客服是如何制作的?使用WebSocket技术!

登录后的界面

 

网页聊天客服是如何制作的?使用WebSocket技术!

webSocket代码

后台,我们采用的是java代码。这里因为是入门,我们没有采用spring框架,而是采用了最基本的webSocket包。这两个包可以在tomcat文件夹下面的lib文件夹找到。

 

网页聊天客服是如何制作的?使用WebSocket技术!

使用的包

前后台通讯方式采用的是json方式。所以引入了Gson包。

数据库使用了两个表:

 

网页聊天客服是如何制作的?使用WebSocket技术!

非常简单的表,mysql可以直接使用

 

网页聊天客服是如何制作的?使用WebSocket技术!

后台部分代码

主要使用的是@ServerEndpoint注解,以及@OnOpen@OnMessage注解。

@ServerEndpoint注解表示ws的路径。

@OnOpen表示连接时触发该方法

@OnMessage 表示服务器收到消息时触发

 

网页聊天客服是如何制作的?使用WebSocket技术!

聊天时可以发送图片和表情

发送图片文件采用的方式还是http方式。

将发送人和接收人和文件使用FormData封装起来,然后使用ajax保存到服务器中。然后再将服务器保存的地址发给对方。

聊天系统没有加密。只是简单的制作。有兴趣的可以私聊我,可以发源代码给你,因为平台限制,不能在文章发链接,见谅了。



Tags:WebSocket   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
最近工作中需要开发前端操作远程虚拟机的功能,简称 WebShell。基于当前的技术栈为 react+django,调研了一会发现大部分的后端实现都是 django+channels 来实现 websocket 服务。...【详细内容】
2021-09-13  Tags: WebSocket  点击:(52)  评论:(0)  加入收藏
前言:作为一个刚踏入职场的实习生,我很幸运参加了某个政府项目,并且在项目中负责一个核心模块功能的开发,而不是从头到尾对数据库的crud。虽然我一直心里抱怨我的工作范围根本...【详细内容】
2021-05-24  Tags: WebSocket  点击:(231)  评论:(0)  加入收藏
1)通知功能:保持一个长连接,当服务端游新的消息,能够实时的推送到使用方。像知乎的点赞通知、评论等,都可以使用WebSocket通信。某些使用H5的客户端,为了简化开发,也会使用WebSocke...【详细内容】
2021-03-03  Tags: WebSocket  点击:(157)  评论:(0)  加入收藏
背景:一般与服务端交互频繁的需求,可以使用轮询机制来实现。然而一些业务场景,比如游戏大厅、直播、即时聊天等,这些需求都可以或者说更适合使用长连接来实现,一方面可以减少轮询...【详细内容】
2020-12-17  Tags: WebSocket  点击:(156)  评论:(0)  加入收藏
1. 前言Websocket是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送...【详细内容】
2020-11-11  Tags: WebSocket  点击:(100)  评论:(0)  加入收藏
前段时间我有这样一个需求,想和一个异地的人一起看电影,先后在网上找了一些方案,不过那几个案都有一些缺点...【详细内容】
2020-10-21  Tags: WebSocket  点击:(92)  评论:(0)  加入收藏
1. 前言Websocket是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数...【详细内容】
2020-09-18  Tags: WebSocket  点击:(97)  评论:(0)  加入收藏
前言服务器和客户端保持长连接通信,实现方式比较多。有很多成熟的框架可以完成,底层无非都是对Socket流的封装和使用。一、SOCKET原理Socket大致是指在端到端的一个连接中,这...【详细内容】
2020-08-06  Tags: WebSocket  点击:(75)  评论:(0)  加入收藏
1. 心跳重连原由 心跳和重连的目的用一句话概括就是客户端和服务端保证彼此还活着,避免丢包发生。websocket连接断开有以下两种情况:前端断开在使用websocket过程中,可能会出现...【详细内容】
2020-07-29  Tags: WebSocket  点击:(308)  评论:(0)  加入收藏
用这些简化了 WebSockets 的开源支持工具来控制你的流媒体。 来源:https://linux.cn/article-12347-1.html 作者:Kevin Sonney 译者:Xingyu.Wang(本文字数:4340,阅读时长大约:6 分...【详细内容】
2020-06-25  Tags: WebSocket  点击:(96)  评论:(0)  加入收藏
▌简易百科推荐
为了构建高并发、高可用的系统架构,压测、容量预估必不可少,在发现系统瓶颈后,需要有针对性地扩容、优化。结合楼主的经验和知识,本文做一个简单的总结,欢迎探讨。1、QPS保障目标...【详细内容】
2021-12-27  大数据架构师    Tags:架构   点击:(5)  评论:(0)  加入收藏
前言 单片机开发中,我们往往首先接触裸机系统,然后到RTOS,那么它们的软件架构是什么?这是我们开发人员必须认真考虑的问题。在实际项目中,首先选择软件架构是非常重要的,接下来我...【详细内容】
2021-12-23  正点原子原子哥    Tags:架构   点击:(7)  评论:(0)  加入收藏
现有数据架构难以支撑现代化应用的实现。 随着云计算产业的快速崛起,带动着各行各业开始自己的基于云的业务创新和信息架构现代化,云计算的可靠性、灵活性、按需计费的高性价...【详细内容】
2021-12-22    CSDN  Tags:数据架构   点击:(10)  评论:(0)  加入收藏
▶ 企业级项目结构封装释义 如果你刚毕业,作为Java新手程序员进入一家企业,拿到代码之后,你有什么感觉呢?如果你没有听过多模块、分布式这类的概念,那么多半会傻眼。为什么一个项...【详细内容】
2021-12-20  蜗牛学苑    Tags:微服务   点击:(9)  评论:(0)  加入收藏
我是一名程序员关注我们吧,我们会多多分享技术和资源。进来的朋友,可以多了解下青锋的产品,已开源多个产品的架构版本。Thymeleaf版(开源)1、采用技术: springboot、layui、Thymel...【详细内容】
2021-12-14  青锋爱编程    Tags:后台架构   点击:(21)  评论:(0)  加入收藏
在了解连接池之前,我们需要对长、短链接建立初步认识。我们都知道,网络通信大部分都是基于TCP/IP协议,数据传输之前,双方通过“三次握手”建立连接,当数据传输完成之后,又通过“四次挥手”释放连接,以下是“三次握手”与“四...【详细内容】
2021-12-14  架构即人生    Tags:连接池   点击:(17)  评论:(0)  加入收藏
随着移动互联网技术的快速发展,在新业务、新领域、新场景的驱动下,基于传统大型机的服务部署方式,不仅难以适应快速增长的业务需求,而且持续耗费高昂的成本,从而使得各大生产厂商...【详细内容】
2021-12-08  架构驿站    Tags:分布式系统   点击:(23)  评论:(0)  加入收藏
本系列为 Netty 学习笔记,本篇介绍总结Java NIO 网络编程。Netty 作为一个异步的、事件驱动的网络应用程序框架,也是基于NIO的客户、服务器端的编程框架。其对 Java NIO 底层...【详细内容】
2021-12-07  大数据架构师    Tags:Netty   点击:(17)  评论:(0)  加入收藏
前面谈过很多关于数字化转型,云原生,微服务方面的文章。虽然自己一直做大集团的SOA集成平台咨询规划和建设项目,但是当前传统企业数字化转型,国产化和自主可控,云原生,微服务是不...【详细内容】
2021-12-06  人月聊IT    Tags:架构   点击:(23)  评论:(0)  加入收藏
微服务看似是完美的解决方案。从理论上来说,微服务提高了开发速度,而且还可以单独扩展应用的某个部分。但实际上,微服务带有一定的隐形成本。我认为,没有亲自动手构建微服务的经历,就无法真正了解其复杂性。...【详细内容】
2021-11-26  GreekDataGuy  CSDN  Tags:单体应用   点击:(35)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条