(附源码)springboot高校学生健康打卡系统的设计与实现 毕业设计 021009

news/2024/4/15 13:47:24

基于springboot 高校学生健康打卡系统

摘 要

2019年12月19号中国武汉发生第一例新冠病毒的到来,大家都在听从政府的号召在居家隔离,不管是在城市还是在乡镇、农村,这引起我的注目,设计一套高校学生健康打卡系统,疫情防控需要大家共同努力、团结对校园学生进行了新型冠状病毒肺炎防控知识普及和宣传教育,通过校园公告栏、楼道张贴宣传单、校园广播每日循环广播、校园微信群等多种形式,从个人防护知识、校园防护知识、外出公共场所防护知识、新型冠状病毒肺炎医学知识、就医流程五个方面,有针对性地向在校同学普及防疫知识。充分做到疫情防控人人知晓、人人参与认识病毒的可怕,最好方式就是建立校区的平台信息,并对其进行管理。

系统采用了Java技术,将所有业务模块采用以浏览器交互的模式,选择MySQL作为系统的数据库,开发工具选择My eclipse来进行系统的设计。基本实现了高校学生健康打卡系统应有的主要功能模块,本系统有管理员、教师、学生。管理员:管理员:首页、用户管理(管理员、教师、学生)更多管理(班级管理、通知公告、每日安排、每日打卡、学生请假、学生日记、疫情上报)。教师;教师:首页、学生管理、通知公告、每日安排、每日打卡、学生请假、学生日记、疫情上报。学生;首页、通知公告、每日安排、每日打卡、学生请假、学生日记、疫情上报管理等。

对系统进行测试后,改善了程序逻辑和代码。同时确保系统中所有的程序都能正常运行,所有的功能都能操作,并且该系统有很好的操作体验,实现了对于高校学生健康打卡系统对学生管理、教师管理、政府部门双赢。

关键词:数据通信;Java语言;数据存储

College Students' health punch in system based on springboot

Abstract

The first COVID-19 came to China in December 19, 2019. Everyone is following the government's call to isolate at home. Whether in city or in town or countryside, this has attracted my attention. A closed management system for students' epidemic situation has been designed. The epidemic prevention and control needs concerted efforts of the whole family. The Wuhan campus has carried out the popularization and education of New Coronavirus pneumonia prevention and control through campus bulletin boards. A variety of forms such as flyers, campus circular daily broadcast, campus WeChat group and so on are publicized on the corridor, from the five aspects of personal protection knowledge, campus protection knowledge, knowledge of public places, knowledge of New Coronavirus pneumonia, and medical treatment process, aiming to popularize epidemic prevention knowledge among students at school. The best way to fully realize that everyone knows and participates in the prevention and control of the epidemic and understand the terrible of the virus is to establish the platform information of the campus and manage it.

The system adopts Java technology, adopts the mode of browser interaction for all business modules, selects MySQL as the database of the system, and selects my eclipse as the development tool to design the system. Basically realized the main functional modules of the student epidemic closed management system. The system has administrators, teachers and students. Administrator: Administrator: home page, user management (administrator, teacher, student) and more management (class management, notice and announcement, daily arrangement, daily clock in, student leave, student diary, epidemic reporting). teacher; Teacher: homepage, student management, notice and announcement, daily arrangement, daily clock in, student leave, student diary, epidemic report. student; Home page, notice and announcement, daily arrangement, daily clock in, student leave, student diary, epidemic reporting management, etc.

After testing the system, the program logic and code are improved. At the same time, it ensures that all programs in the system can operate normally and all functions can be operated, and the system has a good operation experience, which realizes the win-win of the closed management system for students, teachers and government departments.

Keywords: data communication; Java language; data storage

目录

第1章 绪论 1

1.1 研究背景 1

1.2 开发现状 1

第2章 相关技术介绍 3

2.1 开发技术 3

2.2 MVVM模式 3

2.3 Mysql数据库 3

2.4 B/S结构 4

2.5 SSM框架介绍 4

2.6 Vue.js 主要功能 4

第3章 系统分析 6

3.1 可行性分析 6

3.1.1 技术可行性分析 6

3.1.2 经济可行性分析 6

3.1.3 操作可行性分析 6

3.2 功能需求分析 6

3.3 数据流程分析 9

第4章 系统设计 11

4.1 系统架构设计 11

4.2 系统功能结构 11

4.3 功能模块设计 12

4.4 数据库设计 13

4.4.1 概念模型 13

4.4.2 关系模型 13

4.4.3 数据表 14

第5章 系统实现 21

5.1 登录模块的实现 21

5.2.1  用户首页模块 22

5.2.2每日安排模块 22

5.2.3每日打卡模块 23

5.2.4学生请假模块 23

5.3管理员子系统模块的实现 24

5.3.1学生管理模块 24

5.3.2每日安排管理模块 24

5.3.3每日打卡模块 26

5.3.4教师管理模块 26

第6章 系统测试 28

6.1 测试目的 28

6.2 测试过程 28

6.3 测试结果 29

第7章 总结与展望 31

参考文献 32

致谢 34

  1. 绪论
    1. 研究背景

由于新冠病毒突然其来给社区带来压力增大,学生的防疫知识还没有得到普及,学生也不知如何应对,在政府在大力支持下,让有需要的学生得到校园的悉心照顾。

近年来,随着我国经济的不断发展,平台的管理制度越来越多。每个高校学生健康打卡系统也都将通过计算机进行整体智能化操作,对于高校学生健康打卡系统功能所牵扯的数据都是通过学生进行高校学生健康打卡系统等相关的数据信息内容、并且可以进行管理员在线处理选择管理员,可以通过系统进行分配,传统的防疫方式信息已经无法满足学生的需求。为此开发了本高校学生健康打卡系统 ,为学生提供一个基于高校学生健康打卡系统管理 ,同时方便管理员在线了解情况,管理员通过系统对首页、用户管理(管理员、教师、学生)更多管理(班级管理、通知公告、每日安排、每日打卡、学生请假、学生日记、疫情上报)等详细情况进行操作。该系统满足了学生对高校学生健康打卡系统信息获取的需求,并且信息可以及时、准确、有效地进行查看并且系统化、标准化和有效的工作。

    1. 开发现状

随着社会的发展和科学技术的进步,互联网技术越来越受欢迎。网络传播的生活方式逐渐受到广大人民群众的喜爱。越来越多的互联网爱好者开始在互联网上满足他们的基本需求,同时逐渐进入各个居民的生活起居。互联网具有许多优点,例如便利性,速度,高效率和低成本。因此,类似于高校学生健康打卡系统 ,满足学生疫情防控知识的需求,不仅是方便学生随时查看信息的途径,而且还能提高管理效率。

本文首先以高校学生健康打卡系统过程的基本问题作为研究对象。在开发系统之前,我们对现有状况进行了详细的调查和分析。最后,我们利用计算机技术开发了一套完整合适的大学生疫情在校封闭管理系统,该系统的实现主要优势是:该系统主要采用计算机技术开发,它方便快捷;系统可以通过管理员界面查看学生、老师的所有信息管理。

高校学生健康打卡系统是一款方便、快捷、实用的信息服务查询软件。随着智能网络在全球市场的不断普及以及各种智能平台的使用,系统的开发与学生在校的日常需求相关,作为中国主流智能的技术开发系统,自然需要这样的软件来满足更多学生的需求和体验。

1.3研究内容

高校学生健康打卡系统的开发及实现,所需要的工作内容:

(1)首先是确定选题,确定好所要做的系统,并对系统的背景及现在面临的一些问题等进行系统的初步确认。

(2)系统确认完成后,结合系统开发的需求进行确认系统开发所使用的技术,本高校学生健康打卡系统的开发使用JAVA技术,数据库进行平台的搭建开发,确认好使用的技术进行技术分析,所使用的技术是否可以完成高校学生健康打卡系统的实现。

(3)确定好系统使用的技术,进行在线确认系统所划分的学生角色,并且根据学生角色划分确定所要设计的功能模块,对于高校学生健康打卡系统的设计主要划分别为管理员和教师、学生三个角色,并所使用的功能模块也相应不同,但是系统的数据库实现的内容是交互的,学生跟老师可以随时根据自己的需求进行查看疫情信息,管理员获取到所有学跟老师的详细数据信息,并根据需求进行第一时间处理解决。

(4)系统的功能模块确认完成后进行程序及界面的设计,设计完成后,并且通过测试来判断程序是否完善,对于系统测试,需要不同的学生进行不同的内容编辑及提交,及使用不同的测试方式找出程序中存在的漏洞,并对程序出现的漏洞问题进行在线解决处理,如果测试系统没有任何问题时,可以将系统上传进行正式操作使用。

  1. 相关技术介绍
    1.  开发技术

本系统前端部分基于MVVM模式进行开发,采用B/S模式,后端部分基于Java的ssm框架进行开发。

前端部分:前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信,Element UI组件库使页面快速成型,项目前端通过栅格布局实现响应式,可适应PC端、平板端、手机端等不同屏幕大小尺寸的完美布局展示。

后端部分:采用ssm作为开发框架,同时集成MyBatis、Redis等相关技术。

    1.  MVVM模式

MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。MVVM 就是将其中的View 的状态和行为抽象化,让我们将视图 UI 和业务逻辑分开。当然这些事 ViewModel 已经帮我们做了,它可以取出 Model 的数据同时帮忙处理 View 中由于需要展示内容而涉及的业务逻辑。微软的WPF带来了新的技术体验,如Silverlight、音频、视频、3D、动画……,这导致了软件UI层更加细节化、可定制化。同时,在技术层面,WPF也带来了 诸如Binding、Dependency Property、Routed Events、Command、DataTemplate、ControlTemplate等新特性。MVVM(Model-View-ViewModel)框架的由来便是MVP(Model-View-Presenter)模式与WPF结合的应用方式时发展演变过来的一种新型架构框架。它立足于原有MVP框架并且把WPF的新特性糅合进去,以应对客户日益复杂的需求变化。

    1. Mysql数据库

科技的进步,给日常带来许多便利:教室的投影器用到了虚拟成像技术,数码相机用到了光电检测技术,比如超市货物进出库的记录需要一个信息仓库。这个信息仓库就是数据库,而这次的高校学生健康打卡系统也需要这项技术的支持。

用MySQL这个软件,是因为它能接受多个使用者访问,而且里面存在Archive等。它会先把数据进行分类,然后分别保存在表里,这样的特别操作就会提高数据管理系统自身的速度,让数据库能被灵活运用。MySQL的代码是公开的,而且允许别人二次编译升级。这个特点能够降低使用者的成本,再搭配合适的软件后形成一个良好的网站系统。虽然它有缺点,但是综合各方面来说,它是使用者的主流运用的对象。

    1. B/S结构

B/S(Browser/Server)比前身架构更为省事的架构。它借助Web server完成数据的传递交流。只需要下载浏览器作为客户端,那么工作就达到“瘦身”效果, 不需要考虑不停装软件的问题[9]。

    1. SSM框架介绍

SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容)。常作为数据源较简单的web项目的框架。

1.6.1 Spring

Spring就像是整个项目中装配bean的大工厂,在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象。也可以称之为项目中的粘合剂。

Spring的核心思想是IoC(控制反转),即不再需要程序员去显式地`new`一个对象,而是让Spring框架帮你来完成这一切。

1.6.2 SpringMVC

SpringMVC在项目中拦截用户请求,它的核心Servlet即DispatcherServlet承担中介或是前台这样的职责,将用户请求通过HandlerMapping去匹配Controller,Controller就是具体对应请求所执行的操作。SpringMVC相当于SSH框架中struts。

1.6.3 mybatis

mybatis是对jdbc的封装,它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件,Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时,通过sqlSessionFactory拿到一个sqlSession,再执行sql命令。

页面发送请求给控制器,控制器调用业务层处理逻辑,逻辑层向持久层发送请求,持久层与数据库交互,后将结果返回给业务层,业务层将处理逻辑发送给控制器,控制器再调用视图展现数据。

    1.   Vue.js 主要功能

Vue.js是一套构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue采用自底向上增量开发的设计。Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整合。另一方面,Vue 完全有能力驱动采用单文件组件和Vue生态系统支持的库开发的复杂单页应用。

Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习,非常容易与其它库或已有项目整合。另一方面,在与相关工具和支持库一起使用时,Vue.js 也能驱动复杂的单页应用。

  1. 系统分析
    1. 可行性分析

系统的开发环境和配置都是可以自行安装的,系统使用ssm框架开发,使用比较成熟的Mysql数据库进行对系统前台及后台之间相关的数据交互,根据技术语言对数据库,结合需求进行修改维护,可以使得系统运行更具有稳定性和安全性,从而完成实现系统的开发。

      1. 技术可行性分析

所谓的技术可行性就是在限定时间,前期拟定的功能能否被满足。在开发设计上是否会遇上解决不了的问题。做完的项目能否被很好地应用,如果存在缺点在后期的维护上是否存在很大的难度。在对这个系统评估后,认定已存在的技术能达成目标。用java技术来实现动态的页面,嵌入低依赖性的设计模式,灵活的数据库,配合稳定的服务器,整个系统的运行效率大大提升。由此可见,在技术层面达成目标不是非非之想。

      1. 经济可行性分析

在项目上使用的工具大部分都是是当下流行开源免费的,所以在开发前期,开发时用于项目的经费将会大大降低,不会让开发该软件在项目启动期受到经费的影响,所以经济上还是可行的。尽量用最少的花费去满足用户的需求。省下经费用于人工费,以及设备费用。将在无纸化,高效率的道路上越走越远。

      1. 操作可行性分析

本系统实现功能的操作很简单,普通电脑的常见配置就可以运行本软件,并且只要粗通电脑使用的基本常识就可以流畅的使用本软件。电脑具备连接互联网的能力,并且可以正常访问系统,并不需要操作者有什么高超的能力,只需了解业务流程,并且按照专业知识进行正确操作即可,所以高校学生健康打卡系统具备操作可行性。

    1. 功能需求分析

在系统开发设计前,应该对功能做初步设想,清楚这个管理系统有什么板块,每个板块有什么功能,整体的设计是否满足使用者的需求,接着对所开发的系统功能进行的详细分析总结,从而设计出完整的系统并将其实现。用户和开发人员的交流分析,使其达到最佳理解程度,使系统功能达到最佳。

学生后台功能图如下所示。

 

图3-1 学生后台功能图

管理员后台功能图如下所示。

 

图3-2 管理员用例图

教师后台功能图如下所示。

 

图3-3 教师后台功能图

高校学生健康打卡系统在对需求做解析后,整个系统主要分为三个部分:管理员、教师和学生,每个模块下的分支功能不一样。对功能做出如下说明:

学生模块:

账号登录认证。

管理个人资料信息,修改可修改的信息项。

每日安排(健康打卡、请假、日记)添加和查询已有安排的记录。

教师模块:

个人资料管理,修改删除自己的信息。

学生的添加与查询、每日安排的查询、健康打卡的查询、请假管理的查询与审核请假、日记管理的查询及删除、通知公告的查询、日记统计的查看。

管理员模块:

系统用户的管理,管理和添加删除管理员,可以设置登录权限,或者删除所有用户账号。

教师管理,添加教师的具体信息与查询教师同时也具备删除教师。

通知管理,添加发布公告查询公告和删除公告的功能。

学生管理,查询学生的信息,也具备修改和删除功能。

每日安排管理,查询学生安排的信息,也具备修改和删除功能。

健康打卡管理,查询学生打卡的信息,也具备修改和删除功能。

请假管理,查询学生请假的信息,也具备修改和删除功能。

日记管理,查询学生日记的信息,也具备修改和删除功能。

日记统计,查询统计视图。

系统管理,系统的备份功能。

非功能需求分析

系统非功能需求有非常多,比如性能需求、可承载最大用户数、稳定性、易用性需求等。本系统分析时考虑到易用性需求,因为系统是给人使用的,所以必须充分从用户的角度出发,考虑用户体验,使系统易理解易上手易操作。

    1. 数据流程分析

零层数据流程图包括了登录、用户功能和检索维护等模块,在登录模块使用到的数据存储有用户账户文档,用户功能模块需要的存储是用户各功能模块数据文档,检索维护是使用以上这些数据文档通过关键词进行检索。

系统的零层数据流图如下图所示。

 

图3-2系统数据流图(零层)

一层数据流程图是对零层数据流程图的细化,将登录细分为填制登录数据和完善数据,用户功能细分为用户基本功能和用户主要功能。

系统的一层数据流图如下图所示。

 

图3-3系统数据流图(一层)

  1. 系统设计
    1. 系统架构设计

目前B/S体系的系统主要的数据访问方式是:通过浏览器页面用户可以进入系统,系统可以自动对用户向服务器发送的请求进行处理,处理请求是在系统后台中进行的,用户在浏览器页面上进行相应操作,就能够看到服务端传递的处理结果。高校学生健康打卡系统主要分为视图-模型-控制三层架构设计。在视图层中,主要是操作在服务器端向客户端反馈并显示的数据,在模型层中,主要处理相关的业务逻辑、数据整合等,最后的控制层它介于视图和模型之间,主要是调整两层之间的关系,最终落实数据的传递。

系统架构图如下图所示。

 

图4-1系统架构图

    1. 系统功能结构

系统设计的目的是分析系统包括的所有功能结构,为开发人员设计开发和实现系统做好准备工作。经过前期的需求调查、分析和整理之后,确定的总体需求主要包括多个模块,分别是:系统用户管理、教师管理、通知公告管理、班级管理、学生管理、每日安排原来管理、健康打卡管理、请假管理、日记管理、日记统计、数据备份。系统整体角色分为三个部分,一是学生、二是教师、最后是管理员。权限分布也是很明显,普通用户是在除去浏览信息之外还具有查询和管理自己账户信息、教师资料修改、每日安排查询、健康打卡查询、请假查询、日记查询、通知公告查询、日记统计查询等权限;管理员是最高权限拥有者。

系统功能结构图如下图所示。

图4-2系统功能结构图

 

    1. 功能模块设计

用户管理模块

该模块是为所有用户登录设计的,如学生用户这种普通用户登录后只能进行自己的普通功能操作(如个人信息修改),管理员和超级管理员登录后有不同的权限,管理员不能超越权限。超级管理员能对整个系统的数据进行管理,主要是用户的登录权限以及用户登录后在系统里的操作权限。

每日安排模块

学生和安排存在关系为一对多,根据每日安排来将安排数据传入到系统数据中,操作人为教师用户,然后生成每日安排列表,学生可查看个人历史安排列表每条数据右边有删除和编辑按钮,来完成相应的删除和更新功能。

健康打卡模块

学生来录如打卡数据,点击打卡按钮,依次填写要录入的打卡个人状态信息数据,身体状态信息点击提交按钮,将数据提交至数据库,然后刷打卡数据页面,每条数据右边有删除和编辑按钮,来完成相应的删除和更新功能。

请假模块

学生录入请假数据,点击请假录入按钮,依次填写要录入的请假信息数据,点击提交按钮,将数据提交至数据库,然后刷新请假数据页面,每条数据右边有删除和编辑按钮,来完成相应的删除和更新功能。

日记模块

学生点击日记管理菜单,点击添日记,添加心情,日记内容提交成功后,公告数据页面刷新,新数据成功载入页面。

    1. 数据库设计
      1. 概念模型

对于一个要开发的系统来说,E-R图可以让别人能更快更轻松的了解此系统的事务及它们之间的关系。根据系统分析阶段所得出的结论确定了在高校学生健康打卡系统中存在着多个实体分别是用每日安排、健康打卡、请假、日记、学生、教师。

系统总体ER图如下图所示。

 

图4-4系统总体ER图

      1. 关系模型

管理员(管理员id、用户名、密码、权限)

教师管理(教师工号、密码、教师姓名、性别、身份证、电话、职称、助教课程、照片)

通知公告(标题、内容、附件、发布人)

学生管理(学号、密码、姓名、性别、身份证、电话、院系、班级、照片、教师工号、添加时间)修改删除详情。

每日安排管理(学号、学生姓名、班级、院系、教师工号添加时间)修改删除详情。

健康打卡管理(学号、学生姓名、班级、院系、教师工号、个人状态、身体状态、当前地址、添加时间)修改删除详情。

请假管理(请假单号、请假类型、请假开始时间、请假结束时间、是否离校、相关凭证、学号、姓名、班级、院系、教师工号、添加时间、)修改删除详情。

日记管理(学号、学生姓名、班级、院系、教师工号、心情、添加时间)修改删除详情。

      1. 数据表

数据库逻辑结构就是将E-R图在数据库中用具体的字段进行描述。用字段和数据类型描述来使对象特征实体化,最后形成具有一定逻辑关系的数据库表结构。高校学生健康打卡系统所需要的部分数据结构表如下表所示。

class_management

字段名称

类型

长度

不是null

主键

字段说明

class_management_id

int

11

主键

班级管理ID

class_name

varchar

64

班级名称

headmaster

varchar

64

班主任

contact_number

varchar

64

联系电话

class_size

int

11

班级人数

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

daily_schedule

字段名称

类型

长度

不是null

主键

字段说明

daily_schedule_id

int

11

主键

每日安排ID

student_number

int

11

学号

student_name

varchar

64

学生姓名

teacher_job_number

int

11

教师工号

teacher_name

varchar

64

教师姓名

class_name

varchar

64

班级名称

record_date

date

0

记录日期

schedule

text

0

时间安排

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

epidemic_reporting

字段名称

类型

长度

不是null

主键

字段说明

epidemic_reporting_id

int

11

主键

疫情上报ID

student_number

int

11

学号

student_name

varchar

64

学生姓名

teacher_job_number

int

11

教师工号

teacher_name

varchar

64

教师姓名

class_name

varchar

64

班级名称

report_type

varchar

64

上报类型

nucleic_acid_results

varchar

64

核酸结果

detection_time

datetime

0

检测时间

health_code

varchar

255

健康码

remarks

text

0

备注

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

notice_announcement

字段名称

类型

长度

不是null

主键

字段说明

notice_announcement_id

int

11

主键

通知公告ID

title

varchar

64

标题

relevant_attachments

varchar

255

相关附件

publisher

varchar

64

发布人

release_date

date

0

发布日期

content

text

0

内容

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

punch_in_every_day

字段名称

类型

长度

不是null

主键

字段说明

punch_in_every_day_id

int

11

主键

每日打卡ID

student_number

int

11

学号

student_name

varchar

64

学生姓名

teacher_job_number

int

11

教师工号

teacher_name

varchar

64

教师姓名

class_name

varchar

64

班级名称

record_date

date

0

记录日期

today_temperature

varchar

64

今日体温

physical_state

varchar

64

身体状态

punch_in_address

varchar

64

打卡地址

health_code

varchar

255

健康码

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

student

字段名称

类型

长度

不是null

主键

字段说明

student_id

int

11

主键

学生ID

student_number

varchar

64

学号

student_name

varchar

64

学生姓名

class_name

varchar

64

班级名称

teacher_job_number

int

11

教师工号

teacher_name

varchar

64

教师姓名

examine_state

varchar

16

审核状态

recommend

int

11

智能推荐

user_id

int

11

用户ID

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

student_diary

字段名称

类型

长度

不是null

主键

字段说明

student_diary_id

int

11

主键

学生日记ID

student_number

int

11

学号

student_name

varchar

64

学生姓名

teacher_job_number

int

11

教师工号

teacher_name

varchar

64

教师姓名

class_name

varchar

64

班级名称

mood

varchar

64

心情

date

date

0

日期

content

longtext

0

内容

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

students_ask_for_leave

字段名称

类型

长度

不是null

主键

字段说明

students_ask_for_leave_id

int

11

主键

学生请假ID

student_number

int

11

学号

student_name

varchar

64

学生姓名

teacher_job_number

int

11

教师工号

teacher_name

varchar

64

教师姓名

class_name

varchar

64

班级名称

leave_type

varchar

64

请假类型

leave_days

int

11

请假天数

start_time

datetime

0

开始时间

end_time

datetime

0

结束时间

relevant_vouchers

varchar

255

相关凭证

reason_for_leave

text

0

请假原因

examine_state

varchar

16

审核状态

examine_reply

varchar

255

审核回复

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

teacher

字段名称

类型

长度

不是null

主键

字段说明

teacher_id

int

11

主键

教师ID

teacher_job_number

varchar

64

教师工号

teacher_name

varchar

64

教师姓名

examine_state

varchar

16

审核状态

recommend

int

11

智能推荐

user_id

int

11

用户ID

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

  1. 系统实现
    1. 登录模块的实现

系统的登录窗口是用户的入口,用户只有在登录成功后才可以进入访问。通过在登录提交表单,后台处理判断是否为合法用户,进行页面跳转,进入系统中去。

登录合法性判断过程:用户输入账号和密码后,系统首先确定输入输入数据合法性,然后在login.jsp页面发送登录请求,调用src下的mainctrl类的dopost方法来验证。

用户登录模块的IPO如下所示:

输入:用户名和密码。

处理:

1)检测用户输入的账号、密码是否正确及在数据库已对应存在。

2)从数据库中提取记录,并储存在本地的session中(timeout默认=30min)。

3)根据用户名,将其显示在系统首页上。

输出:是否成功的信息。

登录流程图如下所示。

 

图5-1登录流程图

系统登录界面如下所示。

 

图5-2系统登录界面

5.2用户子系统模块的实现

5.2.1  用户首页模块

系统呈现出一种简洁大方的首页:界面简约、鳞次栉比,用户能轻车熟路的使用。出于对系统使用群体广泛的顾虑,应有良好性能的后台。

如下图所示为系统的首页界面。

 

图5-3系统首页界面

5.2.2每日安排模块

每日安排学生编辑学号、教师工号、教师姓名、班级名称、学生账号、学生姓名、记录日期等内容,并可根据需要进行修改、删除等操作。如图5-4所示。

 

图5-4每日安排界面图

5.2.3每日打卡模块

每日打卡学生编辑学号、教师工号、教师姓名、班级名称、学生账号、学生姓名、记录日期、今日体温等内容,并可根据需要进行修改、删除等操作。如图5-5所示。

 

图5-5每日打卡录入界面如图

5.2.4学生请假模块

学生请假学生编辑学号、教师工号、教师姓名、班级名称、学生账号、学生姓名、请假类型、请假天数等内容,并可根据需要进行修改、删除等操作。如图5-6所示。

 

图5-6学生请假申请界面

5.3管理员子系统模块的实现

5.3.1学生管理模块

学生在yhzhgl查看学生信息,先使用sql语句查询出所有学生表的数据,然后调用PageManager.getPages(url,4,sql, request ),返回一个ArrayList的对象,在for循环里,使用jsp得到每个ArrayList对象的数据,在jsp页面中解析ArrayList对象,得到其各个键值对的值。

学生管理界面如下图所示。

 

图5-7学生管理界面

5.3.2每日安排管理模块

添加安排信息时,输入必填字段后,表现层的KechengController接受传过来的安排信息参数,再调用KechengController类的addKecheng方法,经过KechengService业务层到KechengMapper持久层的处理,完成对整个添加安排信息的操作。addKecheng方法也和用户管理中的addUser方法类似,同时做添加和修改工作。

修改安排信息时,选择需要修改的安排进行修改,调用KechengController控制器的editKecheng方法,拿到该安排原本的信息并显示到页面,管理员再对需要修改的安排信息字段进行修改,完成后调用addKecheng方法,调用业务层的updateByKey方法,更新数据库的安排信息表的数据。

每日安排管理流程图如下所示。

 

图5-8每日安排管理流程图

每日安排界面如下图所示。

 

图5-9每日安排添加界面

5.3.3每日打卡模块

每日打卡页面可查看学号、教师工号、教师姓名、班级名称、学生账号、学生姓名、记录日期、今日体温等内容,并可根据需要进行修改、删除等操作

 

图5-10每日打卡界面

5.3.4教师管理模块

删除教师时,选择需要删除的教师进行删除,把主键的uId传到JiaoshiController控制器,再调用控制器的deleteJiaoshi方法,数据经过JiaoshiService业务层解析和处理,请求JiaoshiMapper持久层调用deleteByPrimaryKey方法操作数据库将教师数据从数据库中删除。

查找教师时,输入需要查找的教师名,调用getData方法获取所有数据并且进行分页,把获取到的所有数据显示到视图上,这时候只需要用脚本方法便能快速查找,不涉及对数据库操作。

教师管理流程图如下所示。

 

图5-11教师管理流程图

教师添加界面如下图所示。

 

图5-12教师添加界面

  1. 系统测试
    1. 测试目的

在对该系统进行完详细设计和编码之后,就要对高校学生健康打卡系统的程序进行测试,检测程序是否运行无误,反复进行测试和修改,使之最后成为完整的软件,满足用户的需求,实现预期的功能。

    1. 测试过程

在软件的测试过程中,通常测试人员需要针对不同的功能模块设计多种测试用例。通过测试用例能够及时发现代码业务逻辑上是否与真实的业务逻辑相对应,及时发现代码上或逻辑上的缺陷,以此来来完善系统,提高软件产品的质量,使软件具有良好的用户体验。

登录测试用例表如下所示。

表6-1登录测试用例

测试性能

用户或操作员登录系统

用例目的

测试用户或操作员登录系统时功能是否正常

前提条件

进入用户登录页面或操作员登录页面

输入条件

预期输出

实际情况

各项信息不予填写,直接点击登陆按钮

不允许登录,提示填写账号相关信息

一致

填写错误的登录名或密码后点击登录系统

提示用户名或密码错误,要求重新填写进行登录

一致

填写与验证码信息不一致的信息

系统显示出提示信息,表明验证码错误,要求重新填写

一致

每日安排测试用例表如下所示。

表6-2课程成绩测试用例

测试性能

用户进行成绩课程的操作

用例目的

测试用户进行安排操作时,系统的功能是否正常

前提条件

用户进入安排详情页,该每日安排能够被成功

输入条件

预期输出

实际情况

用户未登录,点击成绩按钮

跳转至登录页面,提示用户先进性登录

一致

正常的登录用户,点击成绩按钮

系统弹出提示框,提示用户成绩成功,同时该课程的状态更改为已成绩状态

一致

请假管理测试用例表如下所示。

表6-3课程管理测试用例

测试性能

请假管理相关信息管理功能

用例目的

测试系统后台操作员对请假管理相关信息进行管理的功能是否正常

前提条件

登录系统后台进入相关管理页面

输入条件

预期输出

实际情况

普通操作员登录,点击进入课程相关信息管理的页面

提示非超级用户,权限不够,无法进行相关页面删除

一致

超级操作员登入,删除某个已被删除的请假

提示该请假删除失败

一致

点击增加请假按钮

页面正常跳转

一致

增加请假是,填写已存在的课程编号

提示该编号已存在

一致

    1. 测试结果

经过对此系统的测试,得出该系统足以满足用户日常需求,在功能项目和操作等方面也能满足操作员对于其他用户的管理。但是,还有很多功能有待添加,这个系统仅能满足大部分的需求,还需要对此系统的功能更进一步的完善,这样使用起来才能更加的完美。

  1. 总结与展望

通过这次大学生防疫封校管理系统的开发,我参考了很多相关系统的例子,取长补短,吸取了其他系统的长处,逐步对该系统进行了完善,但是该系统还是有很多的不足之处,有待以后进一步学习。

实践证明,大学生防疫封校管理系统有着非常好的发展前景,经过测试运行,系统各项功能都十分完善,界面简洁,使用方便,操作容易,在技术理论上已经成熟。

通过大学生防疫封校管理系统的开发,本人巩固了之前学过的知识,如今将平时所学到的知识融合在设计中,在设计过程中,做了很多的准备,首先,在数据库系统的设计过程中,尤其是在数据库的工作原理、工作特点,对其深刻的讨论,与此同时,对于小型站点来说,最好服务器的选择,其次,利用所学的知识点分析所做的系统,并在此基础上设计。

目前本系统已经上线,正在试运行阶段,用户反馈良好,基本完成用户所需,试运行过程中没有出现阻断性问题,有一些不足和小问题也及时予以修正,系统上线后,为了保证数据的安全性,对系统进行了备份操作,系统备份是每两个月备份一次,数据库备份为每周备份一次,系统部署在租赁的云平台服务器中。

本次系统上线成功后,得到了用户的高度认可,但是在功能上和性能上还需做进一步的研究处理,使其有更高的性能和更好的用户体验。

系统在以后的升级过程中,需要解决一系列用户所提出的问题,例如打印过程中如何避免浏览器的兼容性问题,大量用户访问时,如何保持较高的响应速度,在系统今后的升级过程中将着重解决这些安全性问题。

参考文献

[1]李秋萍,彭辉.高校新冠疫情集中医学观察的防控策略与思考——以中国药科大学为例[J].江苏科技信息,2021,38(36):28-31+35.

[2]金振娅. 全力做好“两节”期间疫情防控[N]. 光明日报,2021-12-30(008).DOI:10.28273/n.cnki.ngmrb.2021.006554.

[3]李雅琴.Java编程语言的优势及其应用实践研究[J].互联网周刊,2021(24):60-62.

[4]徐欢,凌骏.防疫封校期间校园学生活动的组织开展研究——以某职业院校学生读书会活动为例[J].武汉冶金管理干部学院学报,2021,31(04):17-20+23.

[5]韩冰,刘翠焕,黄振华,张波,陈明珠,张潇.人工智能时代下“Java程序设计”课程教学改革[J].科技风,2021(33):98-100.DOI:10.19392/j.cnki.1671-7341.202133033.

[6]丁海洋,王昊翔,姚全珠.基于MVVM框架的汽车销售管理系统设计与实现[J].电子制作,2021(22):55-56+8.DOI:10.16589/j.cnki.cn11-3571/tn.2021.22.019.

[7]杨涛,陈维. 中文版COVID-19恐怖症量表在疫情封校期间的信效度检验[C]//第二十三届全国心理学学术会议摘要集(下).,2021:302.DOI:10.26914/c.cnkihy.2021.039964.

[8]苏文强,刘紫阳,苗玉恒.基于SSM的缺陷管理系统设计与实现[J].大众科技,2021,23(10):4-6+10.

[9]王伟,常庆丽,吴朝霞.基于SSM+Vue的精准帮扶系统研究与实现[J].河南科技,2021,40(27):12-14.

[10]胡开华,张玉静,陈明禄,何文鑫.基于Vue.js的Web应用开发教学案例设计与实现[J].信息与电脑(理论版),2021,33(18):91-94.

[11]喻佳,吴丹新.基于SSM的Web快速开发框架[J].电脑编程技巧与维护,2021(09):31-33.DOI:10.16184/j.cnki.comprg.2021.09.013.

[12]巢晟盛.基于SSM微服务架构下前后端分离的MVVM模型浅析[J].电脑知识与技术,2021,17(23):128-129+141.DOI:10.14004/j.cnki.ckt.2021.2412.

[13]赵志威,张生月,蒋应举,屠晓光.基于SSM的高新技术企业创新能力评价平台设计与实现[J].现代信息科技,2021,5(15):40-42.DOI:10.19850/j.cnki.2096-4706.2021.15.011.

[14]霍鹏宇.后疫情时期“高校封校”下的体育教育思考[J].当代体育科技,2021,11(20):71-73.DOI:10.16655/j.cnki.2095-2813.2010-1579-3836.

[15]方生.基于“Vue.js”前端框架技术的研究[J].电脑知识与技术,2021,17(19):59-60+64.DOI:10.14004/j.cnki.ckt.2021.1863.

[16]宋馨来,张海涛.基于前后端分离和Spring Security的用户登录功能的设计与实现[J].科技创新与应用,2021,11(18):19-21+24.

[17]Dang Tran Khanh,Huy Ta Manh,Dang Ly Hoang,Le Hoang Nguyen. An Elastic Data Conversion Framework: A Case Study for MySQL and MongoDB[J]. SN Computer Science,2021,2(4):

[18]马忠强,牟聪瑞,刘磊.新冠疫情封校期间不同体育运动对航海类学生负面情绪调节自我效能感的中介作用[J].高教学刊,2021,7(14):1-6+11.

[19]Dan Roscigno. Bring Elastic Observability to your Java application[J]. InfoWorld.com,2020:

[20]Benymol Jose,Sajimon Abraham. Performance analysis of NoSQL and relational databases with MongoDB and MySQL[J]. Materials Today: Proceedings,2020,24(Pt 3):

致谢

光阴似箭,一晃大学生活即将过去了。一直以严谨的态度和积极的热情投身于学习和工作中,虽然有竞争,也有泪水,但是通过我不断学习和奋斗不断的完善自己,不仅很好的完成了我的学业而且也让我的各方面得到了发展,取得了很大的进步。

大学的生活也即将结束,虽然也有许多的不舍,但是终究是要告别的。回想大学的学习生活,有泪水也有汗水。在此期间我严格要求自己,凭着对知识的强烈追求,刻苦钻研,勤奋好学,态度端正,目标明确,牢固的掌握了一些专业知识和技能,做到了理论联系实际。除了专业知识的学习外,我还不断的扩展我的知识面,从不同的领域以不同的方式来获得新的知识。争取成为一名各方面都很合格的大学生。

这次的毕业设计,是我独自完成周期最长,也是耗力最大的一个项目。值得庆幸的是,在我毕业设计完成的过程当中,有许多帮助我的同学和老师。在几个月的开发过程中,我遇到了大大小小无数个问题。是我的舍友和老师,不断地帮助鼓励。

我的指导老师,在自身工作十分繁忙的情况下,依然能做到及时恢复我们发去的问题邮件,并抽时间对我们进行线下的辅导。指出我们设计上的失误,逻辑错误以及学习规划问题,可以说没有导师的帮助,我的毕设会陷入死胡同,是导师为我指点了迷津,像迷雾中的路灯,为我指明方向!

免费领取本源代码,请关注点赞+私信


http://www.ppmy.cn/news/917599.html

相关文章

为什么地球上只有一个硅谷?

本文由 Medium 和 Leslie Berlin 授权《好奇心日报》发布。Leslie Berlin 是参与了斯坦福大学硅谷档案项目的历史学家,也是《微芯片背后的人:罗伯特诺伊斯和硅谷的崛起(The Man Behind the Microchip: Robert Noyce and the Invention of Sil…

质变的小米:从铁人三项到AIoT

2月11日消息, 国际调研机构Canalys发布了一组最新数据,数据显示小米在乌克兰市场2018年Q4季度首次夺得排名第一,在西欧市场小米成功跻身前五,并以415.1%的同比增长速度成为西欧市场增长最快的手机品牌。这标志着小米国际化业务再次…

什么是Web 2.0

2001年秋天互联网公司(dot-com)泡沫的破灭标志着互联网的一个转折点。许多人断定互联网被过分炒作,事实上网络泡沫和相继而来的股市大衰退看起来像是所有技术革命的共同特征。股市大衰退通常标志着蒸蒸日上的技术已经开始占领中央舞台。假冒者被驱逐&…

新一代平板电脑 三星Galaxy Note 10.1将于本月末发布 - TECH2IPO创见

新一代平板电脑 三星Galaxy Note 10.1将于本月末发布 - TECH2IPO创见 新一代平板电脑 三星Galaxy Note 10.1将于本月末发布 - TECH2IPO创见 新一代平板电脑 三星Galaxy Note 10.1将于本月末发布 在手机屏幕大小的问题中,三星Galaxy Note系列一直在刷新屏幕大小的上限…

Android屏幕旋转总结

转自:http://www.myexception.cn/operating-system/1452058.html 1. ProjectConifg.mk中定义宏MTK_LCM_PHYSICAL_ROTATION180,定义此宏后,Surface Flinger会读取rotate属性对画面进行反转刷新,因此正常开机后的所有画面…

Linux下软件安装的命令

源码安装 以源代码安装软件,每次都需要配置操作系统、配置编译参数、实际编译,最后还要依据个人喜好的方式来安装软件。这个过程很麻烦很累人。 RPM安装软件的默认路径: 注意: /etc 配置文件放置目录/usr/bin 一些可执行文件/usr/lib 一些程…

从星座文化走红背后,看其发展新前景

前不久,微博知名星座博主同道大叔在北京西单大悦城举办了一系列以星座为主题的活动,涵盖“星座好奇屋”、“星座名人堂”、“狮子座霸气高校”以及“狮王扭蛋机”四大展区的星座奇趣展和狮子月生日趴吸引了不少年轻人的注意。 在今年初,星座…

业务知识记录

目录 一.认识目标用户 1.1用户分析体系 1.1.1 用户标签 1.1.2用户画像 1.1.3用户需求挖掘 1.1.4用户生命周期 1.1.5用户细分 1.1.6用户分层 1.2用户增长 1.2.1用户增长 1.2.2用户活跃 1.2.5用户流失 二.理解营销策略:数据助力3大场景 2.1营销的基本概…

万字长文 | 一文带你读懂账号体系

本文由作者 阿境 于社区发布 经手过诸多项目,行业各异,类型各异,但却有个共同点:均涉及到账号体系,看似不难,但深究起来,却也值得思考,细细品味。 于是乎,便有了这篇文章…

2021流行词“私域流量”

今天中国网民数量已经超过10亿,趋近中国人口总数,也就是说互联网上的公域流量饱和了,但竞争企业还在不断增加,流量获取成本水涨船高。如果以前是大家一起在海洋里捞鱼的时代,那接下来就是自己养鱼的时代了,…

助你获取微信亿级流量的21种小程序推广攻略

21种小程序推广攻略 从2017年1月到2018年12月,近两年时间,小程序已然成为炙手可热的流量风口,很多企业纷纷入局其中,都希望从这个庞大的流量池里分一杯羹。他们当中,有的已经脱颖而出,成为大家耳熟能详的头部小程序,但更多的还在艰难求索,深陷推广泥沼无法自拔。 因此,…

一文读懂账号体系产品设计

一、账号体系的概念及价值 账号体系是用户在各平台上的通行证。 平台给与用户可持续的服务,用户在平台上获取价值,中间的媒介,便是账号体系。 阿境将其理解为维系用户与平台之间的枢纽。 注:本文中,账号账户&#xff0…

阿里、京东、亚马逊为何如此重视重构“会员”?

两天前,屈臣氏集团宣布在全球推出VIP尊尚会员计划,将在2019年初之前推广至24个营运市场。升级后的会员将针对不同地区推出不同的服务。 同样是会员业务调整,一周前,饿了么与汉堡王宣布,将于9月底打通双方的会员体系&am…

UE5【C++】 编程概念和技术

文章目录 前言虚函数和纯虚函数宏和预处理器引用和指针内存管理模板和STL异常处理总结前言 在虚幻引擎中使用C++编程可以让我们更深入地了解引擎的内部机制,并且可以通过编写高效的代码来提高游戏性能。下面是一些C++编程概念和技术的介绍。 虚函数和纯虚函数 在C++中,虚函…

【微信小程序】使用WxNotificationCenter实现复杂的事件通信功能,在任意页面中订阅事件、发送事件和取消订阅事件

在微信小程序中,如果需要实现复杂的事件通信功能,可以使用第三方库来辅助实现。以下是一些常用的第三方库示例: WxNotificationCenter WxNotificationCenter是一个基于发布/订阅模式的事件通知库,可以在微信小程序中实现跨页面的…

一寸证件照是多大?怎么制作和修改证件照?

一寸证件照是我们生活中常见的证件照大小之一,它的大小是25mm35mm,我们的身份证、护照、等证件都需要附上一张一寸证件照。同时,在各种考试、招聘等场合也需要提交一张一寸照片。此外,随着各类证件的电子化,我们还需要…

Linux网络---网络预备

文章目录 计算机网络背景计算机网络协议网络传输基本流程 网络中的地址管理 一、计算机网络背景 独立模式: 计算机之间相互独立; 网络互联: 多台计算机连接在一起, 完成数据共享; 局域网LAN: 计算机数量更多了, 通过交换机和路由器连接在一起 广域网WAN: 将远隔千里的计算机…

瀚高数据库安全版V4.5流复制安装手册(Linux)

目录 瀚高数据库安全版V4.5流复制安装手册(Linux) 1. 软件安装 2. 主节点配置 2.1修改参数并创建复制槽 3. 备节点配置 瀚高数据库安全版V4.5流复制安装手册(Linux) 1. 软件安装 (1)【数据库软件安装…

硬盘的读写速度如何计算

硬盘的读写速度如何计算 raid0,速度就是几块硬盘的总和。比如3块硬盘,每块100M/s,就是300M/s。 raid5,就是几块硬盘总和减1。比如3块硬盘,每块100M/s,就是200M/s。 但要注意,sata接口是有带宽极…

访问服务器硬盘速度慢,硬盘读取速度变慢 当前传输模式pio的解决方法

双节到了,但是最火软件站(原烈火网)小编丝毫没有快乐的感觉,因为就在最近朋友的一个网站服务器出现了故障,并且把小编和朋友都给乌龙了一把!当然最终是解决了!在快乐的同时也要给大家分享一下解决的方法! 问…
最新文章