事件监听之统计登录用户人数(含用户名)案例

2024-06-20 01:18

本文主要是介绍事件监听之统计登录用户人数(含用户名)案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(一)创建一个User类,用于封装一个用户信息,该类实现了HttpSessionBindingListener接口中的valueBound()方法
和valueUnbound()方法


1
package entity; 2 3 import javax.servlet.annotation.WebListener; 4 import javax.servlet.http.*; 5 6 @WebListener() 7 public class User implements HttpSessionBindingListener { 8 9 private String username; 10 private String password; 11 private String id; 12 13 public String getUsername() { 14 return username; 15 } 16 17 public void setUsername(String username) { 18 this.username = username; 19 } 20 21 public String getPassword() { 22 return password; 23 } 24 25 public void setPassword(String password) { 26 this.password = password; 27 } 28 29 public String getId() { 30 return id; 31 } 32 33 public void setId(String id) { 34 this.id = id; 35 } 36 37 @Override 38 public void valueBound(HttpSessionBindingEvent event) { 39 //将user存入列表 40 OnlineUser.getInstance().addUser(this); 41 } 42 43 @Override 44 public void valueUnbound(HttpSessionBindingEvent event) { 45 OnlineUser.getInstance().removeUser(this); 46 } 47 }

 (二)创建OnlineUser类,用于存储和获取在用户的列表,而这个列表对于所有的页面来说应该是同一个,故为单例模式。

 1 package entity;
 2 
 3 import java.util.HashMap;
 4 import java.util.Map;
 5 
 6 public class OnlineUser {
 7     private OnlineUser() {}
 8     private static OnlineUser instance = new OnlineUser ();
 9     public static OnlineUser getInstance() {
10         return instance;
11     }
12     private Map userMap = new HashMap();
13     //将用户添加到列表中
14     public void addUser(User user){
15         userMap.put (user.getId (),user.getUsername ());
16     }
17     //将用户移除列表
18     public void removeUser(User user){
19         userMap.remove (user.getId ());
20     }
21     //返回用户列表
22     public Map getOnlineUser() {
23         return userMap;
24     }
25 }

(三)编写一个login.jsp页面,该页面输入用户的登录名和密码,完成用户登录功能 

 1 <%@ page contentType="text/html;charset=UTF-8" language="java" %>
 2 <html>
 3 <head>
 4     <title>Title</title>
 5 </head>
 6 <body>
 7     <center>
 8         <h3>用户登录</h3>
 9     </center>
10 <form action="${pageContext.request.contextPath}/LoginServlet" method="post">
11     <table border="1" width="550px" cellpadding="0" cellspacing="0" align="center">
12         <tr>
13             <td height="35" align="center">用户名</td>
14             <td>
15                 &nbsp;&nbsp;&nbsp;
16                 <input type="text" name="username"/>
17             </td>
18         </tr>
19         <tr>
20             <td height="35" align="center">&nbsp;</td>
21             <td>
22                 &nbsp;&nbsp;&nbsp;
23                 <input type="password" name="password"/>
24             </td>
25         </tr>
26         <tr>
27             <td height="35" colspan="2" align="center">
28                 <input type="submit" value="登录"/>
29                 &nbsp;&nbsp;&nbsp;&nbsp;
30                 <input type="reset" name="重置"/>
31             </td>
32         </tr>
33     </table>
34 </form>
35 </body>
36 </html>

 (四)创建LoginServlet类,用于处理用户登录请求,如果用户登录成功就将该用户的信息封装到User中存入Session对象。

 1 package servlet;
 2 
 3 import entity.OnlineUser;
 4 import entity.User;
 5 
 6 import javax.servlet.ServletException;
 7 import javax.servlet.annotation.WebServlet;
 8 import javax.servlet.http.HttpServlet;
 9 import javax.servlet.http.HttpServletRequest;
10 import javax.servlet.http.HttpServletResponse;
11 import java.io.IOException;
12 import java.util.Map;
13 import java.util.UUID;
14 
15 @WebServlet(name = "LoginServlet",urlPatterns = "/LoginServlet")
16 public class LoginServlet extends HttpServlet {
17     protected void doPost(HttpServletRequest request, HttpServletResponse response)
18             throws ServletException, IOException {
19         request.setCharacterEncoding ("utf-8");
20         response.setContentType ("text/html;charset=utf-8");
21         String username = request.getParameter ("username");
22         String password = request.getParameter ("password");
23         if (username !=null && !username.trim ().equals ("")){
24             //登录成功
25             User user = new User ();
26             user.setId (UUID.randomUUID ().toString ());
27             user.setUsername (username);
28             user.setPassword (password);
29             request.getSession ().setAttribute ("user",user);
30             Map users = OnlineUser.getInstance ().getOnlineUser ();
31             request.setAttribute ("users",users);
32             request.getRequestDispatcher ("/showuser.jsp").forward (request,response);
33         } else {
34             request.setAttribute ("errorMsg","用户名或密码错误");
35             request.getRequestDispatcher ("/login.jsp").forward (request,response);
36         }
37     }
38 
39     protected void doGet(HttpServletRequest request, HttpServletResponse response)
40             throws ServletException, IOException {
41         this.doPost (request,response);
42     }
43 }

 (五)编写一个showuser.jsp,该页面用于显示所有用户登录信息以及当前的登录的用户。

 1 <%@ page contentType="text/html;charset=UTF-8" language="java" %>
 2 <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
 3 <html>
 4 <head>
 5     <title>Title</title>
 6 </head>
 7 <body>
 8   <c:choose>
 9   <c:when test="${sessionScope.user==null}">
10   <a href="${pageContext.request.contextPath}/login.jsp">登录</a>
11       <br/>
12   </c:when>
13       <c:otherwise>
14               欢迎你,${sessionScope.user.username}
15           <a href="${pageContext.request.contextPath}/LogoutServlet">退出</a>
16       </c:otherwise>
17   </c:choose>
18 <hr/>
19 在线用户列表
20 <br/>
21 <c:forEach var="user" items="${requestScope.users}">
22     ${user.value}
23 </c:forEach>
24 </body>
25 </html>

 (六)编写一个LogoutServlet类,用于注销用户登录信息,用户注销后跳转到showuser.jsp页面

 1 package servlet;
 2 
 3 import entity.OnlineUser;
 4 
 5 import javax.servlet.ServletException;
 6 import javax.servlet.annotation.WebServlet;
 7 import javax.servlet.http.HttpServlet;
 8 import javax.servlet.http.HttpServletRequest;
 9 import javax.servlet.http.HttpServletResponse;
10 import java.io.IOException;
11 import java.util.Map;
12 
13 @WebServlet(name = "LogoutServlet",urlPatterns = "/LogoutServlet")
14 public class LogoutServlet extends HttpServlet {
15     protected void doPost(HttpServletRequest request, HttpServletResponse response)
16             throws ServletException, IOException {
17         request.setCharacterEncoding ("utf-8");
18         response.setContentType ("text/html;charset=utf-8");
19         request.getSession ().removeAttribute ("user");
20         Map users = OnlineUser.getInstance ().getOnlineUser ();
21         request.setAttribute ("users",users);
22         request.getRequestDispatcher ("/showuser.jsp").forward (request,response);
23     }
24     protected void doGet(HttpServletRequest request, HttpServletResponse response)
25             throws ServletException, IOException {
26         this.doPost (request,response);
27     }
28 }

(七)使用不同浏览访问,呈现效果如下:

 

这篇关于事件监听之统计登录用户人数(含用户名)案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法