SpringMVC Websoket 测试网页即时通讯

2024-06-15 06:38

本文主要是介绍SpringMVC Websoket 测试网页即时通讯,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说明:测试项目是 springmvc + maven 框架

项目框架图 

1.使用的jar包

 

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

 

2.后端controller层代码

 

AdminController 用户登录类代码
 
 
/**  * 用户controller  *  * @author HUYONG  * @create 2016-12-08  */ @Controller @RequestMapping("/admin") public class AdminController extends BaseController { private static Logger LOGGER = LoggerFactory.getLogger(AdminController.class);   @Autowired  AndysosoService andysosoService;   /**  * 用户登录  * @param userName  * @param password  * @return  */  @RequestMapping(value = "/adminLogin") @ResponseBody  public Result adminLogin(HttpServletRequest request, String userName, String password){ Map<String,Object> map = Maps.newHashMap();  AndysosoAdminDO adminDO = null;  int status = 0;  try { if(StringUtils.isNotEmpty(userName) && StringUtils.isNotEmpty(password)){ adminDO = andysosoService.getAndysosoAdminDO(userName,password);  } if(null != adminDO){ request.getSession().setAttribute("andysosoAdmin",adminDO);  status = 1;  } }catch (Exception e){ LOGGER.error("用户登录出现异常!",e);  } map.put("status",status);  return successResponse(map);  } }

 

 
AndysosoController 进入user_im.jsp 页面的类代码
/*** 功能点controller** @author HUYONG* @create 2016-12-08*/
@Controller
@RequestMapping("/andysoso")
public class AndysosoController extends BaseController{private static Logger LOGGER = LoggerFactory.getLogger(AndysosoController.class);@AutowiredAndysosoService andysosoService;/*** 进入IM页面* @return*/@RequestMapping(value = "/actionImView")public ModelAndView actionImView(HttpServletRequest request){Map<String,Object> map = Maps.newHashMap();String viewUrl = "";try {AndysosoAdminDO adminDO = (AndysosoAdminDO)request.getSession().getAttribute("andysosoAdmin");if(null != adminDO){List<AndysosoAdminDO> adminList = andysosoService.getAndysosoAdminDOList();map.put("andyAdmin",adminDO);map.put("adminList",adminList);viewUrl = "admin/user_im";}}catch (Exception e){LOGGER.error("进入IM页面出现异常!",e);}return createMav(viewUrl,map);}
}
 
WebsocketControllrt 类代码
package com.weijuju.iag.andysoso.personal.controller.websocket;import net.sf.json.JSONObject;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import javax.websocket.*;
import javax.websocket.server.PathParam;
import javax.websocket.server.ServerEndpoint;
import java.io.IOException;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;/*** WebSocket处理类** @author HUYONG* @create 2016-12-06*/
@ServerEndpoint("/websocket.ws/{userCode}")
public class WebsocketControllrt {private static Logger LOGGER = LoggerFactory.getLogger(WebsocketControllrt.class);private static Map<String,Session> webSocketSet = new ConcurrentHashMap<>();/*** 打开连接事触发* @param session*/@OnOpenpublic void onOpen(@PathParam("userCode") String userCode,Session session){LOGGER.info("打开websocket连接...");webSocketSet.put(userCode,session);}/*** 收到客户端消息时触发,并发送给特定用户* @param textJson* @return*/@OnMessagepublic String onMessage(String textJson){String userCode = "";String message = "";try {if(StringUtils.isNotEmpty(textJson)){//解析字符串JSONObject object = JSONObject.fromObject(textJson);userCode = object.getString("sendName");message = object.getString("message");Session session = webSocketSet.get(userCode);if(null != session){session.getBasicRemote().sendText(message);}}} catch (IOException e) {e.printStackTrace();} finally {}return "已经给"+userCode+"发送消息啦!message:"+message;}/*** 异常时触发*/@OnErrorpublic void onError(Throwable throwable) {LOGGER.info("Websocket连接出现异常:");LOGGER.info(throwable.getMessage(), throwable);}/*** 关闭连接时触发*/@OnClosepublic void onClose(@PathParam("userCode") String userCode) {LOGGER.info("Websocket 关闭连接...");webSocketSet.remove(userCode);}
}

 

3.前端JSP页面代码

 

index.jsp 登录页代码 如下:
<%@ page language="java"  pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<body>
<h2>Login Websoket IM View</h2>
<p>请输入用户名:<input id="userName" type="text"/></p>
<p>请输入密码:<input id="password" type="password"/></p>
<button onclick="login()">登录</button>
<hr/>
</body>
<script src="resource/jquery-2.2.4.js"></script>
<script type="text/javascript">function login(){var userName = $("#userName").val();var password = $("#password").val();$.ajax({type:"post",url:"/admin/adminLogin",data:{userName:userName,password:password},dataType:"json",success:function(data){if(data.model.status == 1){window.location.href = "/andysoso/actionImView";}else{alert("登录失败!");}}});}
</script>
</html>

 

user_im.jsp  代码 如下:
<%@ page language="java"  pageEncoding="utf-8"%>
<%@include file="/common/taglibs.jsp" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<body>
<h2>Hello World! Action Websoket  <span>当前登录用户:${andyAdmin.userName}</span></h2>
<div style="width: 100%;"><div style="float: left; width: 70%; height: 100%; background-color: antiquewhite;"><p id="message"></p></div><div id="friend" style="float: right; width: 30%; height: 100%; background-color: aquamarine;"><p>好友列表</p><c:forEach items="${adminList}" var="admin"><p><a href="#" onclick="createReceiveUser(${admin.userName})">${admin.userName}</a></p></c:forEach></div>
</div>
<hr/>
<p>给<span id="sendName">${andyAdmin.userName}</span>发送消息:<input id="text" type="text"/>&nbsp;<button onclick="send()">发送消息</button></p>
<button onclick="closeWebSocket()">关闭WebSocket连接</button>
</body>
<script src="/resource/jquery-2.2.4.js"></script>
<script type="text/javascript">var userName = "${andyAdmin.userName}";var websocket = null;//判断当前浏览器是否支持WebSocketif ('WebSocket' in window) {//取到一个客户端的socketwebsocket = new WebSocket("ws://127.0.0.1:8080/websocket.ws/"+userName);}else {alert('当前浏览器 Not support websocket')}//连接发生错误的回调方法websocket.onerror = function () {setMessageInnerHTML("WebSocket连接发生错误");};//连接成功建立的回调方法websocket.onopen = function () {setMessageInnerHTML("<span style='color:red;'>WebSocket连接成功</span>");}//接收到消息的回调方法websocket.onmessage = function (event) {setMessageInnerHTML(event.data);}//连接关闭的回调方法websocket.onclose = function () {setMessageInnerHTML("WebSocket连接关闭");}//监听窗口关闭事件,当窗口关闭时,主动去关闭websocket连接,防止连接还没断开就关闭窗口,server端会抛异常。window.onbeforeunload = function () {closeWebSocket();}//将消息显示在网页上function setMessageInnerHTML(innerHTML) {document.getElementById('message').innerHTML += innerHTML + '<br/>';}//关闭WebSocket连接function closeWebSocket() {websocket.close();}//发送消息function send() {var message = document.getElementById('text').value;var sendName = $("#sendName").text();var textJson = '{"sendName":"'+sendName+'","message":"'+message+'"}'if(websocket.readyState != 3){websocket.send(textJson);}else{alert("websocket连接已经关闭或者出现网络异常!");}}//指定消息接收人function createReceiveUser(userName){alert("给"+userName+"发送消息");$("#sendName").text(userName);}
</script>
</html>

 

5.页面展示效果

下面是两个浏览器的实际测试效果

 

 

 

 

这篇关于SpringMVC Websoket 测试网页即时通讯的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1062697

相关文章

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环