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

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

相关文章

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

hdu1496(用hash思想统计数目)

作为一个刚学hash的孩子,感觉这道题目很不错,灵活的运用的数组的下标。 解题步骤:如果用常规方法解,那么时间复杂度为O(n^4),肯定会超时,然后参考了网上的解题方法,将等式分成两个部分,a*x1^2+b*x2^2和c*x3^2+d*x4^2, 各自作为数组的下标,如果两部分相加为0,则满足等式; 代码如下: #include<iostream>#include<algorithm

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

客户案例:安全海外中继助力知名家电企业化解海外通邮困境

1、客户背景 广东格兰仕集团有限公司(以下简称“格兰仕”),成立于1978年,是中国家电行业的领军企业之一。作为全球最大的微波炉生产基地,格兰仕拥有多项国际领先的家电制造技术,连续多年位列中国家电出口前列。格兰仕不仅注重业务的全球拓展,更重视业务流程的高效与顺畅,以确保在国际舞台上的竞争力。 2、需求痛点 随着格兰仕全球化战略的深入实施,其海外业务快速增长,电子邮件成为了关键的沟通工具。

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。