基于Springboot + MySQL + Vue 大学新生宿舍管理系统 (含源码)

本文主要是介绍基于Springboot + MySQL + Vue 大学新生宿舍管理系统 (含源码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

📚 前言

📑摘要

📑操作流程

📚 系统架构设计

📚 数据库设计

   💬 管理员信息属性

   💬 学生信息实体属性

   💬 宿舍安排信息实体属性

   💬 卫生检查信息实体属性

📚 系统功能的具体实现

   💬 管理员功能模块

   管理员登录

   公告信息管理

   班级管理

   报修信息管理

 💬 学生功能模块

公告信息管理

宿舍安排管理

缴费信息管理

报修处理管理

✒️ 源码实现

💖 源码获取

😁 联系方式


📚 前言

📑博客主页:@丘比特惩罚陆

💖欢迎关注:点赞收藏⭐留言✒
💬系列专栏:Java Springboot 毕设实战专栏
🎮 加入社区: 丘比特惩罚陆
🥇人生格言:选对方向,每走一步都是进步!
✒️欢迎大佬指正,一起学习!一起加油!

👏 希望大家能小手一动,帮忙点个赞!


📑摘要

   随着科学技术的飞速发展,社会的方方面面、各行各业都在努力与现代的先进技术接轨,通过科技手段来提高自身的优势,新生宿舍管理系统当然也不能排除在外。新生宿舍管理系统以实际运用为开发背景,运用软件工程原理和开发方法,采用springboot框架构建的一个管理系统。整个开发过程首先对软件系统进行需求分析,得出系统的主要功能。

   本新生宿舍管理系统采用的数据库是Mysql,使用springboot框架开发。这种个性化的网上管理系统特别注重交互协调与管理的相互配合,激发了管理人员的创造性与主动性,对新生宿舍管理系统而言非常有利。


📑新生宿舍管理系统的特点

   新生宿舍管理系统主要是为了提高工作人员的工作效率和更方便快捷的满足学生,更好存储所有数据信息及快速方便的检索功能,对系统的各个模块是通过许多今天的发达系统做出合理的分析来确定考虑学生的可操作性,遵循开发的系统优化的原则,经过全面的调查和研究。

📑操作流程

                                                            

                                                           流程图

📚 系统架构设计

体系架构

新生宿舍管理系统的总体架构图形如下:

新生宿舍管理系统的结构:

系统对这些功能进行整合,产生的功能结构图如下:


📚 数据库设计

   💬 管理员信息属性

   💬 学生信息实体属性

   💬 宿舍安排信息实体属性

💬 卫生检查信息实体属性

📚 系统功能的具体实现

   💬 管理员功能模块

    管理员登录

通过填写用户名、密码、角色进行登录;

    公告信息管理

在公告信息管理页面中可以通过查看公告标题、图片、发布日期信息进行详情、修改;

  班级管理

班级管理页面中可以查看班级等信息,并可根据需要对班级管理进行详情、修改或删除等操作;

  学生管理,在学生管理页面中可以查看学号、学生姓名、性别、头像、院系、班级、手机、邮箱、宿舍号等信息,并可根据需要对学生管理进行详情、修改或删除等详细操作;

   报修信息管理

报修信息管理页面中可以查看报修设备、类型、图片、报修内容、报修日期、学号、学生姓名、班级、宿舍号、手机、审核回复、审核状态、审核等内容,并且根据需要对报修信息管理进行详情、修改或删除等详细操作;

 💬 学生功能模块

    公告信息管理

公告信息管理页面中通过查看公告标题、图片、发布日期等信息还可以根据需要对公告信息管理进行修改;

     宿舍安排管理

宿舍安排管理页面中可以查看宿舍号、宿舍类型、图片、位置、可住人数、学号、学生姓名、班级、安排日期等信息内容;

缴费信息管理

缴费信息管理页面中通过查看学号、学生姓名、班级、宿舍号、缴费名称、缴费类型、缴费金额、登记日期、是否支付等内容进行详情;

报修处理管理

报修处理管理页面中通过查看报修设备、类型、报修日期、维修反馈、维修进度、更新日期、学号、学生姓名、班级、宿舍号等内容;

✒️ 源码实现


/*** 宿舍安排* 后端接口* @author * @email * @date 2021-03-18 15:35:05*/
@RestController
@RequestMapping("/susheanpai")
public class SusheanpaiController {@Autowiredprivate SusheanpaiService susheanpaiService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,SusheanpaiEntity susheanpai,HttpServletRequest request){String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("xuesheng")) {susheanpai.setXuehao((String)request.getSession().getAttribute("username"));}EntityWrapper<SusheanpaiEntity> ew = new EntityWrapper<SusheanpaiEntity>();PageUtils page = susheanpaiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, susheanpai), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,SusheanpaiEntity susheanpai, HttpServletRequest request){EntityWrapper<SusheanpaiEntity> ew = new EntityWrapper<SusheanpaiEntity>();PageUtils page = susheanpaiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, susheanpai), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( SusheanpaiEntity susheanpai){EntityWrapper<SusheanpaiEntity> ew = new EntityWrapper<SusheanpaiEntity>();ew.allEq(MPUtil.allEQMapPre( susheanpai, "susheanpai")); return R.ok().put("data", susheanpaiService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(SusheanpaiEntity susheanpai){EntityWrapper< SusheanpaiEntity> ew = new EntityWrapper< SusheanpaiEntity>();ew.allEq(MPUtil.allEQMapPre( susheanpai, "susheanpai")); SusheanpaiView susheanpaiView =  susheanpaiService.selectView(ew);return R.ok("查询宿舍安排成功").put("data", susheanpaiView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){SusheanpaiEntity susheanpai = susheanpaiService.selectById(id);return R.ok().put("data", susheanpai);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){SusheanpaiEntity susheanpai = susheanpaiService.selectById(id);return R.ok().put("data", susheanpai);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody SusheanpaiEntity susheanpai, HttpServletRequest request){susheanpai.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(susheanpai);susheanpaiService.insert(susheanpai);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody SusheanpaiEntity susheanpai, HttpServletRequest request){susheanpai.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(susheanpai);susheanpaiService.insert(susheanpai);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody SusheanpaiEntity susheanpai, HttpServletRequest request){//ValidatorUtils.validateEntity(susheanpai);susheanpaiService.updateById(susheanpai);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){susheanpaiService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 提醒接口*/@RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper<SusheanpaiEntity> wrapper = new EntityWrapper<SusheanpaiEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("xuesheng")) {wrapper.eq("xuehao", (String)request.getSession().getAttribute("username"));}int count = susheanpaiService.selectCount(wrapper);return R.ok().put("count", count);}}

💖 源码获取

点赞、收藏、关注!!!

非无偿源码!获取源码请添加up主!!

😁 联系方式

文章最底下有微信联系方式!!!

这篇关于基于Springboot + MySQL + Vue 大学新生宿舍管理系统 (含源码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Spring AI使用tool Calling和MCP的示例详解

《SpringAI使用toolCalling和MCP的示例详解》SpringAI1.0.0.M6引入ToolCalling与MCP协议,提升AI与工具交互的扩展性与标准化,支持信息检索、行动执行等... 目录深入探索 Spring AI聊天接口示例Function CallingMCPSTDIOSSE结束语

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测