이 기사의 내용은 Java로 webSocket 웹 채팅방을 만드는 방법(코드 포함)에 대한 내용입니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
WebSocket은 네트워크 통신 프로토콜이자 지속성 프로토콜입니다. RFC6455는 통신 표준을 정의합니다.
WebSocket은 HTML5가 제공하기 시작한 단일 TCP 연결에서 전이중 통신을 위한 프로토콜입니다.
전통적인 웹 통신은 http 기술을 사용합니다. http 프로토콜은 상태가 없고 연결이 없는 단방향 애플리케이션 계층 프로토콜입니다. 요청은 하나의 응답에만 대응할 수 있습니다. 통신 요청은 클라이언트에서만 발행할 수 있으며 서버는 요청에 응답합니다. 따라서 서버는 응답을 보내는 데 매우 수동적입니다. 이 수동적 응답은 서버가 적시에 클라이언트에 응답을 적극적으로 푸시하는 것을 방지하기 위한 것입니다. 서버의 상태가 지속적으로 변경되면 클라이언트가 이를 얻기가 매우 어렵습니다. 그것. 비동기식 ajax를 자주 사용하여 긴 폴링을 구현하기 위한 요청을 지속적으로 얻으면 이는 특히 성능을 소모하고 비효율적입니다. (계속 악수를 하든가, 아니면 오래 살든지.)
그리고 webSocket은 서버와 클라이언트 간의 전이중 통신을 허용하므로 한 번 연결이 이루어지면 연결이 유지됩니다. 연결이 설정되면 두 당사자는 여러 번의 핸드셰이크 없이도 서로 통신할 수 있습니다.
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> <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>
3. 백엔드 자바 코드
package controller; import java.io.IOException; import java.util.concurrent.CopyOnWriteArraySet; import javax.net.ssl.SSLSession; import javax.websocket.OnClose; import javax.websocket.OnError; import javax.websocket.OnMessage; import javax.websocket.OnOpen; import javax.websocket.Session; import javax.websocket.server.ServerEndpoint; @ServerEndpoint("/websocket") public class WebScoketServer { private static Integer onlineNum = 0; //当前在线人数,线程必须设计成安全的 private static CopyOnWriteArraySet<WebScoketServer> arraySet = new CopyOnWriteArraySet<WebScoketServer>(); //存放每一个客户的的WebScoketServer对象,线程安全 private Session session; /** * 连接成功 * @param session 会话信息 */ @OnOpen public void onOpen(Session session) { this.session =session; arraySet.add(this); this.addOnlineNum(); System.out.println("有一个新连接加入,当前在线 "+this.getOnLineNum()+" 人"); } /** * 连接关闭 */ @OnClose public void onClose() { arraySet.remove(this); this.subOnlineNum(); System.out.println("有一个连接断开,当前在线 "+this.getOnLineNum()+" 人"); } /** * 连接错误 * @param session * @param error */ @OnError public void onError(Session session, Throwable error) { System.err.println("发生错误!"); error.printStackTrace(); } /** * 发送消息,不加注解,自己选择实现 * @param msg * @throws IOException */ public void onSend(String msg) throws IOException { this.session.getBasicRemote().sendText(msg); } /** * 收到客户端消息回调方法 * @param session * @param msg */ @OnMessage public void onMessage(Session session, String msg) { System.out.println("消息监控:"+msg); for (WebScoketServer webScoketServer : arraySet) { try { webScoketServer.onSend(msg); } catch (IOException e) { e.printStackTrace(); continue; } } } /** * 增加一个在线人数 */ private synchronized void addOnlineNum() { onlineNum++; } /** * 减少一个在线人数 */ private synchronized void subOnlineNum() { onlineNum--; } private Integer getOnLineNum() { return onlineNum; } }
위 내용은 Java로 webSocket 웹 채팅방을 만드는 방법(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!