热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

计算机毕业设计基于SSM的学生考勤管理系统

项目背景在国家的重视教育影响下,教育部门的密确配合下,对考勤进行改革、多样性、等的要求,使学生考勤管理的管理和运营比过去十年前更加理性化

项目背景

在国家的重视教育影响下,教育部门的密确配合下,对考勤进行改革、多样性、等的要求,使学生考勤管理的管理和运营比过去十年前更加理性化。依照这一现实为基础,设计一个快捷而又方便的网上学生考勤管理是一项十分重要并且有价值的事情。对于传统的学生考勤管理控制模型来说,学生考勤管理具有许多不可比拟的优势,首先是快速更新学生考勤的信息,其次是大量信息的管理,最后是高度安全,以及使用简单等特性,这使得学生考勤管理的管理和运营非常方便。进入21世纪,因为科技和经济的迅速发展,人民群众对非物质层面的精神需求正变得越来越多元化。本系统是为了实现这些目标而提出来的。
本论文系统地描绘了整个网上学生考勤管理的设计与实现,主要实现的功能有以下几点:管理员;首页、个人中心、学生管理、教师管理、学校公告管理、班级管理、考勤打卡管理、请假管理、课程名称管理、课表信息管理、学校论坛、系统管理,前台首页;首页、学校公告、考勤打卡、请假、课表信息、学校论坛、个人中心、后台管理、师生交流,教师;首页、个人中心、请假管理、课程名称管理、课表信息管理、学校论坛、系统管理,学生;首页、个人中心、考勤打卡管理、请假管理、学校论坛,等功能,其具有简单的接口,方便的应用,强大的互动,完全基于互联网的特点。
面对此状况,应当利用国内领先的软件技术优势,对于学生考勤管理层面的行业特性,规划出符合该领域需求的学生考勤管理软件。本文研究的主要目的是为实现学生考勤管理的信息化、系统化、规范化,为学生的长远发展奠定了基础。基于学生考勤管理,有着较高的现实应用价值。教师和学生不用受时间和地点的约束,查看学生考勤各项信息。管理员也不用受时间和地点的约束,进行修改、查看各用户的信息与资料等操作。大大减少了很多重复繁琐的工作,加快学生考勤信息管理体制改革,落实学生考勤管理现代化、科学化和信息化。面临错综繁芜的学生考勤管理工作,研发一种可以让学生考勤管理正规化与智能化的数据管控体系就变得迫在眉睫。这是本论文选题的主要目标与研究的价值所在。


功能设计


业务流程分析

登录模块主要满足管理员以及所有用户的权限登录,用户登录流程图如下。
在这里插入图片描述
未有账号的用户可进入注册界面进行注册操作,用户注册流程图如下。
在这里插入图片描述
用户在添加信息时,信息编号自动生成,系统会对添加的信息进行验证,验证通过则添加至数据库,添加信息成功,反之添加失败。添加信息流程如下。
在这里插入图片描述
用户可选择要删除的信息进行信息删除操作,在删除信息时系统提示是否确定删除信息,是则删除信息成功,系统数据库将信息进行删除。删除信息流程图如下。
在这里插入图片描述


系统概要设计

本学生考勤管理选择B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式。适合在互联网上进行操作,只要用户能连网,任何时间、任何地点都可以进行系统的操作使用。系统工作原理图如下。
在这里插入图片描述
整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计,本学生考勤管理结构图如下。
在这里插入图片描述


功能截图

学生登录,通过填写注册时输入的用户名、密码、角色进行登录
在这里插入图片描述
个人信息,在个人信息页面可以查看学号、密码、学生姓名、性别、头像、班级、手机、邮箱等详细内容进行修改
在这里插入图片描述
考勤打卡管理,在考勤打卡管理页面通过填写学号、学生姓名、班级、打卡时间、备注、打卡图等信息进行详情、修改、删除,如图4-3所示。在请假管理页面通过填写请假编号、学号、学生姓名、班级、请假照片、请假理由、请假时间、请假天数、审核回复、审核状态等信息进行详情、删除操作
在这里插入图片描述
在这里插入图片描述
管理员登录,通过填写注册时输入的用户名、密码、角色进行登录
在这里插入图片描述
管理员登录进入学生考勤管理可以查看首页、个人中心、学生管理、教师管理、学校公告管理、班级管理、考勤打卡管理、请假管理、课程名称管理、课表信息管理、学校论坛、系统管理等信息。
学生管理,在学生管理页面中可以通过填写学号、密码、学生姓名、性别、头像、班级、手机、邮箱等内容进行详情、修改、删除,还可以根据需要对教师管理进行详情,修改或删除等详细操作在这里插入图片描述
在这里插入图片描述
班级管理,在班级管理页面中可以查看班级等信息,并可根据需要对已有班级管理进行修改或删除等操作
在这里插入图片描述
课程名称管理,在课程名称管理页面中可以查看课程名称等信息,并可根据需要对已有课程名称管理进行修改或删除等详细操作
在这里插入图片描述
请假管理,在请假管理页面中可以查看请假编号、学号、学生姓名、班级、请假照片、请假理由、请假时间、请假天数、审核回复、审核状态等内容,并且根据需要对已有请假管理进行详情,修改或删除等详细操作
在这里插入图片描述
考勤打卡管理,在考勤打卡管理页面中可以查看学号、学生姓名、班级、打卡时间、备注、打卡图等内容,并且根据需要对已有考勤打卡管理进行详情,修改或删除等详细操作
在这里插入图片描述
课表信息管理,在课表信息管理页面中可以查看班级、星期、课程图、课程一、课程二、课程三、课程四、课程五、课程六、课程七、教师工号、教师姓名等内容,并且根据需要对已有课表信息管理进行详情,修改或删除等详细操作
在这里插入图片描述
学校论坛,在学校论坛页面中可以查看帖子标题、用户名、状态等内容,并且根据需要对已有学校论坛进行详情,修改或删除等详细操作
在这里插入图片描述
教师登录进入学生考勤管理可以查看首页、个人中心、请假管理、课程名称管理、课表信息管理、学校论坛、系统管理等内容。
课程名称管理,在课程名称管理页面中通过填写课程名称等信息,还可以根据需要对课程名称管理进行修改
在这里插入图片描述
课表信息管理,在课表信息管理页面中可以查看班级、星期、课程图、课程一、课程二、课程三、课程四、课程五、课程六、课程七、教师工号、教师姓名等信息内容,并且根据需要对已有课表信息管理进行查看、修改操作
在这里插入图片描述
请假管理;在请假管理页面中通过填写请假编号、学号、学生姓名、班级、请假照片、请假理由、请假时间、请假天数、审核回复、审核状态等内容进行添加、详情、修改
在这里插入图片描述
学校论坛;在学校论坛页面中通过填写帖子标题、用户名、状态等内容进行添加、详情、修改,
在这里插入图片描述
学生考勤管理,在系统首页可以查看首页、学校公告、考勤打卡、请假、课表信息、学校论坛、个人中心、后台管理、师生交流等内容
在这里插入图片描述
登录、学生注册,在学生注册页面可以填写学号、密码、学生姓名、手机、邮箱等详细内容进行登录、学生注册
在这里插入图片描述
个人中心,在个人中心页面通过填写学号、密码、学生姓名、性别、头像、班级、手机、邮箱等信息进行提交,如图4-20所示。考勤打卡页面通过填写学号、学生姓名、班级、打卡时间、备注、打卡图等信息进行提交操作。
在这里插入图片描述


相关代码


数据库配置

# Tomcat
server:tomcat:uri-encoding: UTF-8port: 8080servlet:context-path: /springbootr1tjfspring:datasource:driverClassName: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/springbootr1tjf?useUnicode=true&characterEncoding=utf-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2B8username: rootpassword: 123456# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
# url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=springbootr1tjf
# username: sa
# password: 123456servlet:multipart:max-file-size: 10MBmax-request-size: 10MBresources:static-locations: classpath:static/,file:static/#mybatis
mybatis-plus:mapper-locations: classpath*:mapper/*.xml#实体扫描,多个package用逗号或者分号分隔typeAliasesPackage: com.entityglobal-config:#主键类型 0:"数据库ID自增", 1:"用户输入ID",2:"全局唯一ID (数字类型唯一ID)", 3:"全局唯一ID UUID";id-type: 1#字段策略 0:"忽略判断",1:"非 NULL 判断"),2:"非空判断"field-strategy: 2#驼峰下划线转换db-column-underline: true#刷新mapper 调试神器refresh-mapper: true#逻辑删除配置logic-delete-value: -1logic-not-delete-value: 0#自定义SQL注入器sql-injector: com.baomidou.mybatisplus.mapper.LogicSqlInjectorconfiguration:map-underscore-to-camel-case: truecache-enabled: falsecall-setters-on-nulls: true#springboot 项目mybatis plus 设置 jdbcTypeForNull (oracle数据库需配置JdbcType.NULL, 默认是Other)jdbc-type-for-null: 'null'

控制层(controller)

package com.controller;import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;import javax.servlet.http.HttpServletRequest;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.CommonUtil;
import com.utils.MPUtil;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.ValidatorUtils;/*** 登录相关*/
@RequestMapping("users")
@RestController
public class UserController{&#64;Autowiredprivate UserService userService;&#64;Autowiredprivate TokenService tokenService;/*** 登录*/&#64;IgnoreAuth&#64;PostMapping(value &#61; "/login")public R login(String username, String password, String captcha, HttpServletRequest request) {UserEntity user &#61; userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));if(user&#61;&#61;null || !user.getPassword().equals(password)) {return R.error("账号或密码不正确");}String token &#61; tokenService.generateToken(user.getId(),username, "users", user.getRole());return R.ok().put("token", token);}/*** 注册*/&#64;IgnoreAuth&#64;PostMapping(value &#61; "/register")public R register(&#64;RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !&#61;null) {return R.error("用户已存在");}userService.insert(user);return R.ok();}/*** 退出*/&#64;GetMapping(value &#61; "logout")public R logout(HttpServletRequest request) {request.getSession().invalidate();return R.ok("退出成功");}/*** 密码重置*/&#64;IgnoreAuth&#64;RequestMapping(value &#61; "/resetPass")public R resetPass(String username, HttpServletRequest request){UserEntity user &#61; userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));if(user&#61;&#61;null) {return R.error("账号不存在");}user.setPassword("123456");userService.update(user,null);return R.ok("密码已重置为&#xff1a;123456");}/*** 列表*/&#64;RequestMapping("/page")public R page(&#64;RequestParam Map<String, Object> params,UserEntity user){EntityWrapper<UserEntity> ew &#61; new EntityWrapper<UserEntity>();PageUtils page &#61; userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));return R.ok().put("data", page);}/*** 列表*/&#64;RequestMapping("/list")public R list( UserEntity user){EntityWrapper<UserEntity> ew &#61; new EntityWrapper<UserEntity>();ew.allEq(MPUtil.allEQMapPre( user, "user")); return R.ok().put("data", userService.selectListView(ew));}/*** 信息*/&#64;RequestMapping("/info/{id}")public R info(&#64;PathVariable("id") String id){UserEntity user &#61; userService.selectById(id);return R.ok().put("data", user);}/*** 获取用户的session用户信息*/&#64;RequestMapping("/session")public R getCurrUser(HttpServletRequest request){Long id &#61; (Long)request.getSession().getAttribute("userId");UserEntity user &#61; userService.selectById(id);return R.ok().put("data", user);}/*** 保存*/&#64;PostMapping("/save")public R save(&#64;RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !&#61;null) {return R.error("用户已存在");}userService.insert(user);return R.ok();}/*** 修改*/&#64;RequestMapping("/update")public R update(&#64;RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);UserEntity u &#61; userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));if(u!&#61;null && u.getId()!&#61;user.getId() && u.getUsername().equals(user.getUsername())) {return R.error("用户名已存在。");}userService.updateById(user);//全部更新return R.ok();}/*** 删除*/&#64;RequestMapping("/delete")public R delete(&#64;RequestBody Long[] ids){userService.deleteBatchIds(Arrays.asList(ids));return R.ok();}
}

业务层&#xff08;Service&#xff09;


package com.service;import java.util.List;
import java.util.Map;import org.apache.ibatis.annotations.Param;import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.service.IService;
import com.entity.UserEntity;
import com.utils.PageUtils;/*** 系统用户*/
public interface UserService extends IService<UserEntity> {PageUtils queryPage(Map<String, Object> params);List<UserEntity> selectListView(Wrapper<UserEntity> wrapper);PageUtils queryPage(Map<String, Object> params,Wrapper<UserEntity> wrapper);}

数据访问层&#xff08;Dao&#xff09;

package com.dao;import java.util.List;import org.apache.ibatis.annotations.Param;import com.baomidou.mybatisplus.mapper.BaseMapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.plugins.pagination.Pagination;
import com.entity.UserEntity;/*** 用户*/
public interface UserDao extends BaseMapper<UserEntity> {List<UserEntity> selectListView(&#64;Param("ew") Wrapper<UserEntity> wrapper);List<UserEntity> selectListView(Pagination page,&#64;Param("ew") Wrapper<UserEntity> wrapper);}

推荐阅读
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • WhenIusepythontoapplythepymysqlmoduletoaddafieldtoatableinthemysqldatabase,itdo ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • 本文主要复习了数据库的一些知识点,包括环境变量设置、表之间的引用关系等。同时介绍了一些常用的数据库命令及其使用方法,如创建数据库、查看已存在的数据库、切换数据库、创建表等操作。通过本文的学习,可以加深对数据库的理解和应用能力。 ... [详细]
  • Jboss的EJB部署描述符standardjaws.xml配置步骤详解
    本文详细介绍了Jboss的EJB部署描述符standardjaws.xml的配置步骤,包括映射CMP实体EJB、数据源连接池的获取以及数据库配置等内容。 ... [详细]
  • 1.使用通用mapper时实体类的mapper接口(即普通的dao接口)继承了通用mapper接口后,在依赖注入实体类的mapper接口时 ... [详细]
  • 本文介绍了Paxos的世界中关于复制日志与状态机的概念和重要性。通过存储日志来实现数据的持久化,并通过日志流来记录数据的变化,而不是直接持久化数据本身。这样做的好处是简化了持久化存储的操作,并且方便多机之间的数据同步。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 数据库(外键及其约束理解)(https:www.cnblogs.comchenxiaoheip6909318.html)My ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • 先看一段错误日志:###Errorqueryingdatabase.Cause:com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransie ... [详细]
  • 本文介绍了Windows Vista操作系统中的用户账户保护功能,该功能是为了增强系统的安全性而设计的。通过对Vista测试版的体验,可以看到系统在安全性方面的进步。该功能的引入,为用户的账户安全提供了更好的保障。 ... [详细]
author-avatar
蘇靖雯jingwensu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有