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

目录

[📚 前言](#📚 前言)

📑摘要

📑操作流程

[📚 系统架构设计](#📚 系统架构设计)

[📚 数据库设计](#📚 数据库设计)

[💬 管理员信息属性](#💬 管理员信息属性)

[💬 学生信息实体属性](#💬 学生信息实体属性)

[💬 宿舍安排信息实体属性](#💬 宿舍安排信息实体属性)

[💬 卫生检查信息实体属性](#💬 卫生检查信息实体属性)

[📚 系统功能的具体实现](#📚 系统功能的具体实现)

[💬 管理员功能模块](#💬 管理员功能模块)

管理员登录

公告信息管理

班级管理

报修信息管理

[💬 学生功能模块](#💬 学生功能模块)

公告信息管理

宿舍安排管理

缴费信息管理

报修处理管理

[✒️ 源码实现](#✒️ 源码实现)

[💖 源码获取](#💖 源码获取)

[😁 联系方式](#😁 联系方式)


📚 前言

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

💖欢迎关注:点赞收藏⭐留言✒
💬系列专栏:Java Springboot 毕设实战专栏

🎮 加入社区: 丘比特惩罚陆

🥇人生格言:选对方向,每走一步都是进步!

✒️欢迎大佬指正,一起学习!一起加油!

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


📑摘要

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

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


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

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

📑操作流程

流程图

📚 系统架构设计

体系架构

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

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

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


📚 数据库设计

💬 管理员信息属性

💬 学生信息实体属性

💬 宿舍安排信息实体属性

💬 卫生检查信息实体属性

📚 系统功能的具体实现

💬 管理员功能模块

管理员登录

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

公告信息管理

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

班级管理

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

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

报修信息管理

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

💬 学生功能模块

公告信息管理

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

宿舍安排管理

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

缴费信息管理

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

报修处理管理

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

✒️ 源码实现

java 复制代码
/**
 * 宿舍安排
 * 后端接口
 * @author 
 * @email 
 * @date 2021-03-18 15:35:05
 */
@RestController
@RequestMapping("/susheanpai")
public class SusheanpaiController {
    @Autowired
    private 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主!!

😁 联系方式

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

相关推荐
songbaoxian4 分钟前
ElasticSearch
java·linux·elasticsearch
非 白19 分钟前
【Java】代理模式
java·开发语言·代理模式
Good Note29 分钟前
Golang的静态强类型、编译型、并发型
java·数据库·redis·后端·mysql·面试·golang
m0_748236581 小时前
跟据spring boot版本,查看对应的tomcat,并查看可支持的tomcat的版本范围
spring boot·后端·tomcat
web151173602231 小时前
Spring Boot项目中解决跨域问题(四种方式)
spring boot·后端·dubbo
我就是我3521 小时前
记录一次SpringMVC的406错误
java·后端·springmvc
向哆哆1 小时前
Java应用程序的跨平台性能优化研究
java·开发语言·性能优化
ekkcole2 小时前
windows使用命令解压jar包,替换里面的文件。并重新打包成jar包,解决Failed to get nested archive for entry
java·windows·jar
翱翔-蓝天2 小时前
Spring Boot 3 集成 RabbitMQ 实践指南
spring boot·rabbitmq·java-rabbitmq
luckilyil2 小时前
RabbitMQ学习—day6—springboot整合
spring boot·rabbitmq·java-rabbitmq