基于java+springboot+vue的校园管理系统

项目介绍

随着科学技术的飞速发展,社会的方方面面、各行各业都在努力与现代的先进技术接轨,通过科技手段来提高自身的优势,校园管理系统当然也不能排除在外。校园管理系统是以实际运用为开发背景,运用软件工程原理和开发方法,采用springboot框架构建的一个管理系统。整个开发过程首先对软件系统进行需求分析,得出系统的主要功能。接着对系统进行总体设计和详细设计。总体设计主要包括系统功能设计、系统总体结构设计、系统数据结构设计和系统安全设计等;详细设计主要包括系统数据库访问的实现,主要功能模块的具体实现,模块实现关键代码等。最后对系统进行功能测试,并对测试结果进行分析总结,得出系统中存在的不足及需要改进的地方,为以后的系统维护提供了方便,同时也为今后开发类似系统提供了借鉴和帮助。这种个性化的网上校园管理系统特别注重交互协调与管理的相互配合,激发了管理人员的创造性与主动性,对校园管理系统而言非常有利。

本校园管理系统采用的数据库是Mysql,使用springboot框架开发。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。

在这里插入图片描述

开发环境

编程语言:Java
数据库 :Mysql
系统架构:B/S
后端框架:SpringBoot
编译工具:idea或者eclipse,jdk1.8,maven
支持定做:java/php/python/android/小程序vue/爬虫/c#/asp.net

系统实现

5.1管理员功能模块
管理员登录,通过填写注册时输入的用户名、密码、角色进行登录,如图5-1所示。
在这里插入图片描述

图5-1管理员登录界面图

管理员登录进入校园管理系统可以查看首页、个人中心、院校管理、用户管理、单位类别管理、院校管理员管理、单位管理、通知推送管理、投票信息管理、通知回复管理等信息。
院校管理,在院校管理页面中可以通过填写学院名称、资料文件、学院简介、职工人数、院校账号等信息进行详情、修改、删除等操作,如图5-2所示。还可以根据需要对用户管理进行详情、修改或删除等详细操作,如图5-3所示。
在这里插入图片描述

图5-2院校管理界面图

在这里插入图片描述

图5-3用户管理界面图

单位类别管理,在单位类别管理页面中可以填写单位类别等信息,并可根据需要对单位类别管理进行详情、修改或删除等操作,如图5-4所示。
在这里插入图片描述

图5-4单位类别管理界面图

院校管理员管理,在院校管理员管理页面中可以填写院校账号、负责人姓名、性别、年龄、联系方式、备注等信息,并可根据需要对院校管理员管理进行详情、修改或删除等详细操作,如图5-5所示。
在这里插入图片描述

图5-5院校管理员管理界面图

单位管理,在单位管理页面中可以填写姓名、性别、年龄、照片、个人资料、单位类别、备注、联系方式等信息,并且根据需要对单位管理进行详情、绑定用户、修改或删除等详细操作,如图5-6所示。
在这里插入图片描述

图5-6单位管理界面图

通知推送管理,在通知推送管理页面中可以填写院校账号、负责人姓名、用户账号、用户姓名、通知内容、发送时间等信息,并且根据需要对通知推送管理进行详情、修改或删除等详细操作,如图5-7所示。
在这里插入图片描述

图5-7通知推送管理界面图

投票信息管理,在投票信息管理页面中可以填写候选人姓名、性别、年龄、赞成票、反对票、更新时间等内容,并且根据需要对投票信息管理进行详情、修改或删除等详细操作,如图5-8所示。
在这里插入图片描述

图5-8投票信息管理界面图

通知回复管理,在通知回复管理页面中可以填写院校账号、用户账号、回复内容、回复时间等内容,并且根据需要对通知回复管理进行详情、修改或删除等详细操作,如图5-9所示。
在这里插入图片描述

图5-9通知回复管理界面图

5.2用户功能模块
用户登录进入校园管理系统可以查看首页、个人中心、单位管理、通知推送管理、投票信息管理、通知回复管理等内容。
个人信息,在个人信息页面中通过填写用户账号、用户姓名、性别、年龄、个人资料、照片、联系方式、单位类别等信息还可以根据需要对个人信息进行修改,如图5-10所示。
在这里插入图片描述

图5-10个人信息界面图

单位管理,在单位管理页面中可以查看姓名、性别、年龄、照片、个人资料、单位类别、备注、联系方式等信息内容,并且根据需要对单位管理进行详情等其他详细操作,如图5-11所示。

在这里插入图片描述

图5-11单位管理界面图

通知推送管理,在通知推送管理页面中通过填写院校账号、负责人姓名、用户账号、用户姓名、通知内容、发送时间等内容进行详情、修改、删除等操作,如图5-12所示。
在这里插入图片描述

图5-12通知推送管理界面图

投票信息管理,在投票信息管理页面中通过填写候选人姓名、性别、年龄、赞成票、反对票、更新时间等内容进行详情等操作,如图5-13所示。
在这里插入图片描述

图5-13投票信息管理界面图

5.3院校管理员功能模块
院校管理员登录进入校园管理系统可以查看首页、个人中心、用户管理、单位类别管理、单位管理、通知推送管理、投票信息管理、通知回复管理等内容。
个人信息,在个人信息页面中通过填写院校账号、负责人姓名、性别、年龄、联系方式、备注等信息还可以根据需要对个人信息进行修改等操作,如图5-14所示。
在这里插入图片描述

图5-14个人信息界面图

用户管理,在用户管理页面中可以填写用户账号、用户姓名、性别、年龄、个人资料、照片、联系方式、单位类别等信息内容,并且根据需要对用户管理进行详情、修改或删除等其他详细操作,如图5-15所示。

在这里插入图片描述

图5-15用户管理界面图

单位类别管理,在单位类别管理页面中通过填写单位类别等内容进行详情、修改、删除,如图5-16所示。
在这里插入图片描述

图5-16单位类别管理界面图

通知推送管理,在通知推送管理页面中通过填写院校账号、负责人姓名、用户账号、用户姓名、通知内容、发送时间等内容进行详情、回复等操作,如图5-17所示。
在这里插入图片描述

图5-17通知推送管理界面图

通知回复管理,在通知回复管理页面中通过填写院校账号、用户账号、回复内容、回复时间等内容进行详情、修改、删除等操作,如图5-18所示。
在这里插入图片描述

图5-18通知回复管理界面图

核心代码

package com.controller;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
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.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.TongzhituisongEntity;
import com.entity.view.TongzhituisongView;

import com.service.TongzhituisongService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;


/**
 * 通知推送
 * 后端接口
 * @author 
 * @email 
 * @date 2
 */
@RestController
@RequestMapping("/tongzhituisong")
public class TongzhituisongController {
    @Autowired
    private TongzhituisongService tongzhituisongService;
    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,TongzhituisongEntity tongzhituisong, HttpServletRequest request){
		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("yuanxiaoguanliyuan")) {
			tongzhituisong.setYuanxiaozhanghao((String)request.getSession().getAttribute("username"));
		}
		if(tableName.equals("yonghu")) {
			tongzhituisong.setYonghuzhanghao((String)request.getSession().getAttribute("username"));
		}
        EntityWrapper<TongzhituisongEntity> ew = new EntityWrapper<TongzhituisongEntity>();
		PageUtils page = tongzhituisongService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, tongzhituisong), params), params));

        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,TongzhituisongEntity tongzhituisong, HttpServletRequest request){
        EntityWrapper<TongzhituisongEntity> ew = new EntityWrapper<TongzhituisongEntity>();
		PageUtils page = tongzhituisongService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, tongzhituisong), params), params));
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( TongzhituisongEntity tongzhituisong){
       	EntityWrapper<TongzhituisongEntity> ew = new EntityWrapper<TongzhituisongEntity>();
      	ew.allEq(MPUtil.allEQMapPre( tongzhituisong, "tongzhituisong")); 
        return R.ok().put("data", tongzhituisongService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(TongzhituisongEntity tongzhituisong){
        EntityWrapper< TongzhituisongEntity> ew = new EntityWrapper< TongzhituisongEntity>();
 		ew.allEq(MPUtil.allEQMapPre( tongzhituisong, "tongzhituisong")); 
		TongzhituisongView tongzhituisongView =  tongzhituisongService.selectView(ew);
		return R.ok("查询通知推送成功").put("data", tongzhituisongView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        TongzhituisongEntity tongzhituisong = tongzhituisongService.selectById(id);
        return R.ok().put("data", tongzhituisong);
    }

    /**
     * 前端详情
     */
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        TongzhituisongEntity tongzhituisong = tongzhituisongService.selectById(id);
        return R.ok().put("data", tongzhituisong);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody TongzhituisongEntity tongzhituisong, HttpServletRequest request){
    	tongzhituisong.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(tongzhituisong);
        tongzhituisongService.insert(tongzhituisong);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody TongzhituisongEntity tongzhituisong, HttpServletRequest request){
    	tongzhituisong.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(tongzhituisong);
        tongzhituisongService.insert(tongzhituisong);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody TongzhituisongEntity tongzhituisong, HttpServletRequest request){
        //ValidatorUtils.validateEntity(tongzhituisong);
        tongzhituisongService.updateById(tongzhituisong);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        tongzhituisongService.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<TongzhituisongEntity> wrapper = new EntityWrapper<TongzhituisongEntity>();
		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("yuanxiaoguanliyuan")) {
			wrapper.eq("yuanxiaozhanghao", (String)request.getSession().getAttribute("username"));
		}
		if(tableName.equals("yonghu")) {
			wrapper.eq("yonghuzhanghao", (String)request.getSession().getAttribute("username"));
		}

		int count = tongzhituisongService.selectCount(wrapper);
		return R.ok().put("count", count);
	}
	


}

论文参考

在这里插入图片描述

目 录
摘 要 I
ABSTRACT II
目 录 II
第1章 绪论 1
1.1背景及意义 1
1.2 国内外研究概况 1
1.3 研究的内容 1
第2章 相关技术 3
2.1 B/S架构 4
2.2 Java技术介绍 4
2.3 mysql数据库介绍 4
2.4 springboot框架 5
第3章 系统分析 5
3.1 需求分析 5
3.2 系统可行性分析 5
3.2.1技术可行性:技术背景 5
3.2.2经济可行性 6
3.2.3操作可行性: 6
3.3 项目设计目标与原则 6
3.4系统流程分析 7
3.4.1操作流程 7
3.4.2添加信息流程 8
3.4.3删除信息流程 9
第4章 系统设计 11
4.1 系统体系结构 11
4.2开发流程设计系统 12
4.3 数据库设计原则 13
4.4 数据表 15
第5章 系统详细设计 19
5.1管理员功能模块 20
5.2用户功能模块 23
5.3院校管理员功能模块 24
第6章 系统测试 25
6.1系统测试的目的 25
6.2系统测试方法 25
6.3功能测试 26
结 论 28
致 谢 29
参考文献 30

1、把6个java文件保存到同一文件夹,例如C:\Student.然后将6个java文件分别编译生成相应的字节码(.class)文件,然后,用java 解释器运行主类:C:\Student\java StudentManager 2、使用jar.exe把一些文件压缩成JAR文件,来发布我们的应用程序。我们可以把本java应用程序中涉及到的类文件(*.class)压缩成一个JAR文件,例如StudentManager.jar。 首先,用记事本编写一个清单文件(Manifestfiles): Manifest-Version: 1.0 Main-class: StudentManager Created-By: 1.2.2(Sun Microsystems Inc.) 例如,清单文件命名为moon.mf,保存到C:\Student。 注意:在编写清单文件时,在“Manifest-Version:”和“1.0”之间,“Main-class:”和“StudentManager”之间,以及在“Created-By:”和“1.2.2(Sun Microsystems Inc.)”之间必须有且只有一个空格。 然后,如下生成JAR文件: C:\Student\jar cvfm StudentManager.jar moon.mf *.class 其中,参数C表示要生成一个新的JAR文件;f表示要生成的JAR文件的名字,m表示文件清单文件的名字,v表示生成详细输出到标准输出上。具体运行jar命令请查看 现在就可以将StudentManager.jar拷贝到任何一个安装了java运行环境(jdk版本号须高于1.2.2)的计算机上,只要鼠标双击StudentManager.jar文件就可以运行该java应用程序了。 注意在装了WinRAR解压缩软件的机子上可能不能运行,因此,在发布本系统时,还应该建立一个有如下内容的.bat文件(StudentManager.bat),用记事本编写: javaw -jar StudentManager.jar 保存即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_3306428634

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值