基于 Web 的疫情期间社区出入管理系统的设计与实现
摘要: 随着互联网的发展,“线上化”已经成为常态,如何方便快捷的为用户提供服务的问题越来越突出。针对疫情期间“封城、封路、封社区”的情况,文章设计并实现了基于 Web 的疫情期间社区人员出入管理系统。此系统致力于为社区住户提供安全、便捷、高效、透明的出入程序办理平台。
关键词: 社区管理系统、Web、Java
一、前言
2020年,突如其来的疫情,一场没有硝烟的战争,让人猝不及防。我们度过了有史以来最安静的一个春节,感受到了中国对于突发灾难反应速度之快、力度之大,也见证了中国全国人民关于最“宅”比拼。
在疫情最为紧张的时候,封城封路封小区,需要大量的工作人员在各个出入口登记排查,是一个非常复杂且冗余的工作。当进行这些工作时,人员大量聚集,增加了病毒传播的机会。特别地,像社区这样人员比较集中之地,减少人员聚集、减少办理程序时间是十分有必要的,所以基于 Web 的疫情期间社区出入人员管理系统应运而生。
该系统主要解决社区的四个问题:(1)将线下事务转移到线上,减少人员聚集,提高社区安全性;(2)简化复杂的办事流程,提高办事效率;(3)将社区的人员情况通过软件实时展示,提高信息的透明度,增加住户的安全感;(4)积累数据,进行数据分析,供管理者决策。
客户端是比较流行的软件模式,但是它的问题也非常明显,用户机上安装了许多的软件,每天常用的却极少,这是用户不太喜欢的一个模式。所以,为了给用户良好的体验,本该系统基于 Web,用户只需要打开网页就可以办理相关事务,查询和自己息息相关的社区情况。本设计采用了 B/S 模式软件常用的 Java 语言进行开发,前端用 JSP 进行展示,服务端选择 Servlet 技术,服务器软件使用开源的 Tomcat,数据库使用 MySQL,数据库连接选择了 JDBC,同时使用了阿里巴巴的 Druid 连接池技术。
二、需求分析
2.1 产品适用范围
疫情期间社区出入管理系统是针对像 2020 年这样疫情突发、社区人员出入需要严格管控的情景开发,适用于社区特殊时期的管理或者特殊小区的管理(社区人员外出需申请,外来人员不能随意进入)。
2.2 功能需求
经过调研,我们了解到用户的需求是:当用户使用我们的系统时,需要对用户进行分类选择不同的角色登录至不同的界面。当审核者登录时,系统将跳转至审核者界面,审核者对用户信息进行增删改查;住户登录时,系统跳转到住户界面,住户可以申请外出、确认外出;当门卫登录时,系统跳转到进出人员授权大屏,门卫可以对其授权。
构建用例图如下:
图 2-1 疫情期间社区出入管理系统
该系统设计四个角色:住户、访客、审核者和门卫。其中,住户、审核者和门卫需要登录才能进行操作,而访客则不需要登陆。对各个用例的具体描述如下:
用况:登录
【前置条件:系统成功发布,成功通过浏览器进入】
系统呈现用户名输入框及密码输入框,输入用户名及密码,点击登录就把用户账号及密码与数据库中的内容进行匹配,匹配成功进入主界面,匹配失败提示密码或账号错误。
用况:管理住户信息
【前置条件:审核者成功登录系统】
审核者选择住户信息管理
系统呈现出当前已存在住户的信息,并提供增加,删除,修改和按条件查询的界面。
管理员对信息完成处理(增删改查)后,提示保存,并通知是否操作成功。
用况:审核申请表
【前置条件:审核者成功登录系统】
审核者选择审核申
系统呈现住户当前申请且未处理的申请表,并提供通过和驳回操作。审核者处理完成后,通知操作是否成功。
用况:申请外出
【前置条件:住户成功登录系统】
住户选择申请外出
系统呈现外出申请表单,用户填写表单并提交后,通知是否操作成功。
用况:确认外出
【前置条件:住户成功登录系统】
住户选择外出
系统呈现外出成功,并提示注意安全,早点回家。
用况:授权访客进入
【前置条件:门卫成功登录系统】
门卫选择对应访客离开
系统呈现社区内访客的列表,门卫授权离开后,该访客从列表中消失。
用况:确认住户回家
【前置条件:门卫成功登录系统】
门卫选择对应住户回家
系统呈现外出住户的列表,门卫点击回家按钮后,该住户从列表中消失。
用况:提交身份信息
【前置条件:系统成功发布,成功通过浏览器进入】
访客进入访客身份界面
系统呈现访客信息表,访客填写并提交后,系统通知是否成功进入。
2.3 非功能需求
用户界面需求
需求名称 | 详细要求 |
---|---|
界面简洁 | 保留所必须的文本框,不设置多余菜单及无用文本框及按钮。 |
界面设计 | 采用 bootstrap |
命令交互 | 功能执行后可以得到反馈结果,提示成功还是失败 |
信息显示 | 因为人员出入严格控制,出入人员比较少,所以采用一个列表进行显示,不进行分页。 |
表 2-1 用户界面需求表
软件环境需求
需求名称 | 详细要求 |
---|---|
IntelliJ IDEA | IntelliJ IDEA 2020.1.2 x64 |
JDK | jdk1.8.0_251 |
Tomcat | apache-tomcat-8.5.54 |
MySQL | MySQL5.5.28 |
Chrome 浏览器 | 发布后可以在任意浏览器中运行 |
表 2-2 软件环境需求表
三、总体设计
3.1 结构设计
疫情期间社区出入管理系统的用户,主要包括住户、审核者、访客和门卫。审核者模块包含:住户信息管理,申请表管理,查看社区情况;住户模块包含:申请外出,确认外出;门卫模块包含:授权访客离开,授权住户回家;访客模块仅有填写身份信息。系统总体结构如下图所示:
图 3-1 系统总体结构图
3.2 审核者各模块的分析说明:
3.2.1 住户信息管理
该模块实现添加住户或审核者,根据姓名或住址查询用户,修改住户或审核者信息,这些信息包括姓名、性别、年龄、住址、电话、身份(住户或审核者)。
3.2.2 审核申请表
该模块实现审核者查看未处理的外出申请表,如果申请信息正确且合理,予以审核通过,否则驳回申请。
3.2.3 查看社区情况
该模块实现实时显示社区内访客人员信息和外出住户信息,帮助审核者了解社区情况。
3.3 住户各模块的分析说明:
3.3.1 申请外出
该模块实现住户填写外出申请表(内容包括外出时间、回家时间、申请理由),提交给审核者审核。
3.3.2 确认外出
该模块实现住户外出前点击确认外出,系统将住户的状态修改为外出状态。
3.4 门卫各模块的分析说明:
3.4.1 授权访客离开
该模块实现访客离开时,门卫点击该访客对应的离开按钮,系统将其离开时间写入数据库。
3.4.2 授权住户回家
该模块实现住户回家进入社区时,门卫点击住户回家,系统修改住户状态外在家。
3.5 访客各模块的分析说明:
3.5.1 填写身份信息
该模块实现访客进入社区前填写身份信息(包括电话、姓名、单位),并提交,系统将其身份信息和进入时间写入数据库。
四、数据库设计
4.1 全局 E-R 图(如下图)
图 4-1 全局 E-R 图
E-R 图描述:数据库中共需要三个数据表,“用户”存储住户、审核者和门卫的个人信息和状态,供登录、申请和管理时使用;“访客”存储进出社区访客的个人信息和时间;“申请”存储用户的申请表,包括出入时间。
4.2 关系模式
- 用户(ID,姓名,年龄,性别,电话,权限,住址)
- 申请表(ID,H_ID,C_ID,外出时间,回家时间,申请原因,状态)
- 访客(ID,姓名,电话,单位,进入时间,离开时间)
4.3 数据表
4.1.1 用户信息表
图 3-1 用户信息表
4.1.2 访客信息表
图 3-2 访客信息表
4.1.3 申请信息表
图 3-3 申请信息表
五、界面设计
5.1 系统首页
图 5-1 系统首页
5.2 登录界面
图 5-2 登录界面
5.3 用户信息管理界面
审核者登录并选择住户信息管理后,跳转到住户信息管理界面。如下图:
图 5-3 用户信息管理界面
5.4 用户信息修改界面
图 5-3 用户信息修改界面
5.5 添加用户界面
图 5-5 添加用户界面
六、软件模块设计
该项目采用了经典的 MVC 设计模式。
- Model(模型)表示应用程序核心(比如数据库记录列表)。
- View(视图)显示数据(数据库记录)。
- Controller(控制器)处理输入(写入数据库记录)。
6.1 登录模块的设计
住户、审核者、门卫三个角色在进入首页时,需要选择对应的身份进行登录,用户数据用户名和密码进行登录,登录成功则跳转到对应角色的操作界面,否则保持登录界面,并输出“用户名或密码错误”的提示信息。
图 6-1 登录模块类图
详细描述:类 LoginServlet 从浏览器登录界面中获取用户名和密码,封装成 JaveBean 传递给类 UserviceImpl;类 UserviceImpl 将其传入类 UserDaoImpl;类 UserDaoImpl 将接收到的 JavaBean 与数据库进行对比,若对比成功,返回用户对象,否则返回 null,逆向传递给 LoginServlet;LoginServlet 如果接收到用户对象,则跳转到用户操作界面,否则发送错误信息到浏览器。
6.2 审核者模块设计
图 6-2 审核者模块类图
6.3 申请表模块设计
图 6-3 申请表模块类图
6.4 访客模块设计
图 6-4 访客模块类图
七、系统的实现关键代码
7.1 审核者管理用户界面实现
```c++
@WebServlet("/userListServlet")
public class UserListServlet extends HttpServlet {
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
UserService service = new UserServiceImpl();
List
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
this.doPost(req, res);
}
} ```
7.2 数据库连接
```c++ Druid.propties driverClassName = com.mysql.jdbc.Driver url = jdbc: mysql://127.0.0.1/cmsde username = root password = root initialSize = 5 maxActive = 10 maxWait = 30000
public class JDBCUtil { private static DataSource ds; static { try { // 加载配置文件 Properties pro = new Properties(); InputStream is = JDBCUtil.class.getClassLoader().getResourceAsStream("druid.properties"); pro.load(is); // 初始化连接池对象 ds = DruidDataSourceFactory.createDataSource(pro); } catch(IOException e) { e.printStackTrace(); } catch(Exception e) { e.printStackTrace(); } } / * 获取连接池对象 */ public static DataSource getDataSource() { return ds; } / * 获取Connection对象 */ public static Connection getConnection() throws SQLException { return ds.getConnection(); } } ```
7.3 用户登录获取权限
```c++
@WebServlet("/loginServlet")
public class LoginServlet extends HttpServlet {
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
User user = new User();
Map
if (loginUser.getAuthority().equals("管理员"))
res.sendRedirect(req.getContextPath()+"/checkerHome.jsp");
else if (loginUser.getAuthority().equals("门卫"))
res.sendRedirect(req.getContextPath()+"/doorkeeperWorkServlet");
else res.sendRedirect(req.getContextPath()+"/householdHome.jsp");
} else {
req.setAttribute("login_msg","用户名或密码错误!");
req.getRequestDispatcher("/login.jsp").forward(req,res);
}
}
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
this.doPost(req, res);
}
} ```
7.4 审核者对用户信息进行操作
7.4.1 修改用户信息
```c++
@WebServlet("/updateUserServlet")
public class UpdateUserServlet extends HttpServlet {
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
Map
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
this.doPost(req, res);
}
} ```
7.4.2 添加用户
```c++
@WebServlet("/addUserServlet")
public class AddUserServlet extends HttpServlet {
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
Map
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
this.doPost(req, res);
}
} ```
7.4.3 删除用户
```c++ @WebServlet("/delUserServlet") public class DelUserServlet extends HttpServlet { protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { String id = req.getParameter("id"); UserService service = new UserServiceImpl(); service.deleteUser(id); res.sendRedirect(req.getContextPath()+"/userListServlet"); }
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
this.doPost(req, res);
}
} ```
八、系统测试
8.1 测试计划
针对审核者对系统的需求,对审核者在该系统的登录、新用户的添加、老用户的信息修改和删除进行测试,通过用户信息列表来显示。采用黑盒测试方法进行测试。同时,对非功能需求进行测试,界面中无多余文本框及按钮,操作完成后具有提示,操作结果是否正常显示,提示信息是否正确且友好。
8.2 功能测试用例
功能描述 | 审核者登录,添加一个新用户,并对其进行修改、删除等操作。 | 审核者登录,添加一个新用户,并对其进行修改、删除等操作。 | 审核者登录,添加一个新用户,并对其进行修改、删除等操作。 |
---|---|---|---|
用例目的 | 测试审核者管理用户信息功能是否正常 | 测试审核者管理用户信息功能是否正常 | 测试审核者管理用户信息功能是否正常 |
前提条件 | Web 应用项目发布至服务器上 | Web 应用项目发布至服务器上 | Web 应用项目发布至服务器上 |
输入/动作 | 输入/动作 | 期望的输出/相应 | 实际情况 |
错误登录----审核者登录输入密码错误。 | 错误登录----审核者登录输入密码错误。 | 提示“用户名或密码错误”。 | 提示“用户名或密码错误”。 |
添加----添加一个新用户。 | 添加----添加一个新用户。 | 添加后在用户列表中显示。 | 添加后的用户列表。 |
修改----对添加用户的信息进行修改。 | 修改----对添加用户的信息进行修改。 | 对页面内已有信息进行修改,修改后页面上显示修改后的信息。 | 显示修改后的信息。 |
删除----选择用户,删除。 | 删除----选择用户,删除。 | 删除后,显示成功删除提示,并显示用户列表。 | 选中用户成功删除 |
表 8-1 功能测试用例表
8.3 非功能测试用例
功能描述 | 使用户获得良好的使用体验 | 使用户获得良好的使用体验 | 使用户获得良好的使用体验 |
---|---|---|---|
用例目的 | 测试用户界面设计及反馈 | 测试用户界面设计及反馈 | 测试用户界面设计及反馈 |
前提条件 | Web 应用项目发布至服务器上并成功登录 | Web 应用项目发布至服务器上并成功登录 | Web 应用项目发布至服务器上并成功登录 |
输入/动作 | 输入/动作 | 期望的输出/相应 | 实际情况 |
点击文本框及按钮 | 点击文本框及按钮 | 每个文本框及按钮提供对应的功能,无多余及无反应按钮 | 找不到多余文本框及按钮 |
进行“增删改查”操作 | 进行“增删改查”操作 | 操作成功时进行提示 | 具有提示 |
点击用户信息管理 | 点击用户信息管理 | 显示所有用户信息 | 正常显示 |
表 8-2 非功能测试用例表
8.4 功能测试结果
经过测试,社区管理系统满足审核者对用户的添加、修改、删除、查询操作。
存在的问题:该系统存在一定的安全问题,同一用户名可以在不同浏览器上同时登录,这可能会导致数据库的管理出现问题。其次,该系统的一些界面提示不够友好,需要进一步维护和改善。
错误登录:
图 8-1 错误登录
添加新用户:
图 8-2 添加界面
图 8-3 添加后用户列表
修改用户信息:
图 8-4 修改界面
删除用户:
图 8-5 删除界面
8.5 非功能测试结果
经过观测可以看到,无多余按键及文本框。
图 8-6 界面测试
用户列表显示:
图 8-7 用户列表显示测试
操作提示:
图 8-8 删除操作提示测试
参考文献
蒋少莉,贾艳波.Java Web 程序设计课程教学改革——基于项目驱动的互动式教学模式探索[J].教育现代化,2020,7(07):44-45+52.
朱秀梅,林晓玥,王天东.基层社区数字化应急管理系统构建研究[J/OL].软科学:1-16[2020-06-15]. http://kns.cnki.net/kcms/detail/51.1268.G3.20200612.1511.034.html .
Booch,G,Object-Oriented Analysis and Design with Applications(Third Edition).北京电子工业出版社,2016.5
Cay S.Horstmann,Core Java Volume I-Fundamentals(10th Edition),机械工业出版社,2016.8
参考文献
- 金华市阳光花园社区物业管理系统的设计与实现(电子科技大学·张志伟)
- 金华市阳光花园社区物业管理系统的设计与实现(电子科技大学·张志伟)
- 基于DotNet的社区信息化平台设计与开发(电子科技大学·谢海洲)
- 社区物业管理系统的设计与实现(电子科技大学·刘佳欣)
- 物业信息管理平台的设计与实现(电子科技大学·张芳)
- 金华市阳光花园社区物业管理系统的设计与实现(电子科技大学·张志伟)
- 基于SOA架构的社区管理系统的设计与实现(电子科技大学·任利群)
- 基于JAVA的社区管理和交流平台设计与实现(云南大学·陈威)
- 物业信息管理平台的设计与实现(电子科技大学·张芳)
- 数字化社区网络管理平台的设计与实现(山东大学·李顺廷)
- 基于AngularJS和Bootstrap的社区物业管理系统的设计与研究(杭州电子科技大学·张玉静)
- 基于WebGIS的智慧社区平台设计与实现(南京师范大学·邹思雨)
- 基于WebGIS的智慧社区管理系统的设计与开发(重庆交通大学·杨博)
- 移动社区服务平台的设计与实现(西安电子科技大学·宋博轩)
- 基于SSH社区事务综合管理系统(江西农业大学·纪美珍)
本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:代码助手 ,原文地址:https://m.bishedaima.com/yuanma/35840.html