• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Java如何制作一个webSocket网页聊天室(附代码)

java 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

本篇文章给大家带来的内容是关于Java如何制作一个webSocket网页聊天室(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

一、什么是webSocket

WebSocket 是一种网络通信协议,是持久化协议。RFC6455 定义了它的通信标准。

WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。

二、为什么要使用webSocket

传统的web通信是使用的http技术,http协议是无状态的、无连接的、单向的应用层协议。一次请求只能对应一个响应,通信请求只能由客户端发出,服务端对请求做出响应。所以服务端发出响应是非常被动的,这种被动的响应注定了服务端无法及时的给客户端主动推送响应,如果服务端有连续的状态变化的时候,客户端获取是很困难的。通过频繁使用了异步ajax去不断地获取请求去实现长轮询,这样做是特别消耗性能,而且效率低下。(不停的握手,或者长时间保持live)。

而webSocket允许服务器和客户端之间建立全双工通信,只要建立一次连接,就能一直保持连接状态。一旦建立一次连接,就能双方互相通信,不需要多次握手。

三、实现WEB聊天室

  1. 添加pom.xml,引入jar包

<dependency>      <groupId>javax</groupId>         <artifactId>javaee-api</artifactId>         <version>7.0</version>         <scope>provided</scope> </dependency>

2.建立html和js文件

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>在线聊天室</title><script type="text/javascript" src="./static/jquery-3.2.0.min.js"></script><!-- 最新版本的 Bootstrap 核心 CSS 文件 --><link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"><!-- 最新的 Bootstrap 核心 JavaScript 文件 --><script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script></head><body><b>本文来源gao@!dai!ma.com搞$$代^@码5网@</b>  <div>    <div><span>聊天室</span>         <button class="btn btn-warning" onclick="doClose();">退出聊天</button>    </div>    <div><textarea class="form-control" style="width: 40%;" rows="3" id="contentInp"></textarea></div><hr/>    <div><button class="btn btn-danger" onclick="doClear();">清空会话框</button></div>    <div id="content">开始聊天<br/></div>  </div></body><script type="text/javascript">   var ws = new WebSocket("ws://localhost:8080/ws/websocket"); //controller层url   $(function(){       $("#contentInp").keyup(function(evt){           if(evt.which == 13){ //enter键发送消息               var htm = $("#contentInp").val();               doSend(htm);               $("textarea").empty();           }       });   })      ws.onopen = function(){       appendHtm("连接成功!");   }      // 从服务端接收到消息,将消息回显到聊天记录区   ws.onmessage = function(evt){       appendHtm(evt.data);   }      ws.onerror = function(){       appendHtm("连接失败!");   }      ws.onclose = function(){       appendHtm("连接关闭!");   }      function appendHtm(htm){       ($("#content")[0]).innerHTML += htm +"<br/>"    }      // 注销登录   function doClose(){       ws.close();   }      // 发送消息   function doSend(htm){      // ($("#content")[0]).innerHTML += htm +"<br/>"        ws.send(htm);   }      function doClear(){       $("#content").empty();   }</script></html>

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Java如何制作一个webSocket网页聊天室(附代码)
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址