基于Java+SpringBoot+vue+element实现校园疫情防控系统详细设计和实现

8,095 阅读9分钟

 前言介绍:

      随着社会的快速发展,计算机的影响是全面且深入的。学校管理水平的不断提高,日常生活中学生对校园疫情防控方面的要求也在不断提高,学生的人数更是不断增加,使得校园疫情防控系统的开发成为必需而且紧迫的事情。校园疫情防控系统主要是借助计算机,通过对校园疫情防控系统所需的信息管理,增加学生的选择,同时也方便对广大学生信息的及时查询、修改以及对学生信息的及时了解。校园疫情防控系统对学生带来了更多的便利,该系统通过和数据库管理系统软件协作来满足学生的需求。计算机技术在现代管理中的应用,使计算机成为人们应用现代技术的重要工具。能够有效的解决获取信息便捷化、全面化的问题,提高效率。

功能设计:

技术可行性:技术背景

本企业网站在Windows操作系统中进行开发,并且目前PC机的性能已经可以胜任普通网站的web服务器。系统开发所使用的技术也都是自身所具有的,也是当下广泛应用的技术之一。

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

(1)硬件可行性分析

校园疫情防控系统及信息分析的设计对于所使用的计算机没有什么硬性的要求,计算机只要可以正常的使用进行代码的编写及页面设计就可行,主要是对于服务器有些要求,对于平台搭建完成要上传的服务器是有一定的要求的,服务器必须选择安全性比较高的,然后就是在打开网站必须顺畅,不能停顿太长时间;性价比高;安全性高。

(2)软件可行性分析

开发整个系统使用的是云计算,流量的可扩展性和基于流量的智能调整云计算的优点就是流量的可扩展性和基于流量的智能调整,保障系统的安全和数据信息的及时备份。

因此,我们从两个方面进行了可行性研究,可以看出系统的开发没有问题。

经济可行性

在校园疫情防控系统开发之前所做的市场调研及其他相关的管理系统,都是没有任何费用的,都是通过开发者自己的努力,所有工作都是自己亲力亲为,在碰到自己比较难以解决的问题,大多是通过同学和指导老师的帮助进行相关信息的解决,所以对于校园疫情防控系统的开发在经济上是完全可行的,没有任何费用支出的。

使用比较成熟的技术,系统是基于java的开发,采用Mysql数据库。所以系统在开发人力、财力要求不高,具有经济可行性。

操作可行性:

可操作性主要是对校园疫情防控系统设计完成后,学生的使用体验度,以及管理员可以通过系统随时管理相关的数据信息,并且对于管理员、学生二个用户角色,都可以简单明了的进入到自己的系统界面,通过界面导航菜单可以简单明了地操作功能模块,方便学生信息的操作需求和景点信息管理数据信息,对于系统的操作,不需要专业人员都可以直接进行功能模块的操作管理,所以在系统的可操作性是完全可以的。本系统的操作过程使用的也是界面窗口进行登录,所以操作人员只要会简单的电脑操作就完全可以的。

校园疫情防控系统结构图:

功能截图:

用户首页: 通过内容列表可以获取网站首页、出入登记、疫情知识、论坛信息、疫情公告、个人中心、后台管理、客服等信息操作内容,如图所示

登录注册:学生注册/登陆,通过填写学号、密码、学生姓名、性别、头像、专业、班级、住址省份、市级、县级、手机、邮箱等信息,输入完成后选择注册即可进入校园疫情防控系统,通过学号密码登陆

出入登记:通过出入登记管理内容列表可以获取登记标题、登陆类型、登记时间、备注、学号、学生姓名、性别、头像、实时体温、手机、班级、专业、审核回复、审核状态、审核等信息可进行详情、修改、删除或查看等

疫情知识:通过疫情知识内容列表可以获取标题名称、分类、图片、视频、发布日期等信息可进行详情、修改、删除或查看等操作

论坛交流:通过论坛信息内容列表可以查看、发布帖子等操作

 发布详情:

疫情公告

用户后台管理

管理员后台管理:

管理员首页,管理员进入校园疫情防控系统查看个人中心、核酸检测管理、体温状态管理、学生管理、学生状态管理、休假申请管理、出入登记管理、疫情知识管理、论坛管理、系统管理操作

学生管理: 通过学生管理内容列表获取景区学号、密码、学生姓名、性别、头像、专业、班级、住址省份、市级、县级、手机、邮箱等信息可进行详情、修改、删除或查看操作

核酸检测:

学生状态:

休假管理:通过休假申请管理内容列表可以获取申请编号、申请标题、休假天数、行程城市、途径城市、申请日期等信息可进行详情、修改、删除或查看操作

疫情知识: 通过疫情知识内容列表可以获取标题名称、分类、图片、视频、发布日期等信息可进行详情、修改、删除或查看等操作

论坛和轮播图等: 管理员通过系统管理页面查看疫情公告/客服管理/轮播图等进行上传图片进行添加、删除、修改以及查看并对整个系统进行维护等操作,如图5-8所示

代码实现:




/**
 * 体温状态
 * 后端接口
 * @author 
 * @email 
 * @date 2022-01-10 10:02:51
 */
@RestController
@RequestMapping("/tiwenzhuangtai")
public class TiwenzhuangtaiController {
    @Autowired
    private TiwenzhuangtaiService tiwenzhuangtaiService;
    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,TiwenzhuangtaiEntity tiwenzhuangtai, HttpServletRequest request){
        EntityWrapper<TiwenzhuangtaiEntity> ew = new EntityWrapper<TiwenzhuangtaiEntity>();
		PageUtils page = tiwenzhuangtaiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, tiwenzhuangtai), params), params));

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

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

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(TiwenzhuangtaiEntity tiwenzhuangtai){
        EntityWrapper< TiwenzhuangtaiEntity> ew = new EntityWrapper< TiwenzhuangtaiEntity>();
 		ew.allEq(MPUtil.allEQMapPre( tiwenzhuangtai, "tiwenzhuangtai")); 
		TiwenzhuangtaiView tiwenzhuangtaiView =  tiwenzhuangtaiService.selectView(ew);
		return R.ok("查询体温状态成功").put("data", tiwenzhuangtaiView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        TiwenzhuangtaiEntity tiwenzhuangtai = tiwenzhuangtaiService.selectById(id);
        return R.ok().put("data", tiwenzhuangtai);
    }

    /**
     * 前端详情
     */
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") String id){
        TiwenzhuangtaiEntity tiwenzhuangtai = tiwenzhuangtaiService.selectById(id);
        return R.ok().put("data", tiwenzhuangtai);
    }
    



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

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

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        tiwenzhuangtaiService.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<TiwenzhuangtaiEntity> wrapper = new EntityWrapper<TiwenzhuangtaiEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}


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


}

@Configuration
public class InterceptorConfig extends WebMvcConfigurationSupport{
	
	@Bean
    public AuthorizationInterceptor getAuthorizationInterceptor() {
        return new AuthorizationInterceptor();
    }
	
	@Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(getAuthorizationInterceptor()).addPathPatterns("/**").excludePathPatterns("/static/**");
        super.addInterceptors(registry);
	}
	
	/**
	 * springboot 2.0配置WebMvcConfigurationSupport之后,会导致默认配置被覆盖,要访问静态资源需要重写addResourceHandlers方法
	 */
	@Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
		registry.addResourceHandler("/**")
        .addResourceLocations("classpath:/resources/")
        .addResourceLocations("classpath:/static/")
        .addResourceLocations("classpath:/admin/")
        .addResourceLocations("classpath:/front/")
        .addResourceLocations("classpath:/public/");
		super.addResourceHandlers(registry);
    }
}

 数据设计:

       数据库表是数据库重要的组成部分,其实数据库只是一个框架,数据库表才是数据库的本质,本系统数据库表如下:allusers表:

序号字段名称字段类型大小
1idInt4
2username150
3pwd150
4cx150
5addtimeDateTime8

churudengji表:

序号字段名称字段类型大小
1idInt4
2addtime150
3dengjibiaoti150
4dengjileixingDateTime8
5dengjineirong150
6dengjishijianDateTime8
7beizhu150
8xuehaoDateTime8
9xueshengxingming150
10xingbieDateTime8
11touxiang150
12shishitiwenDateTime8
13shouji
14banjiDateTime8
15zhuanye
16sfshDateTime150
17shhf

xiujiashenqing表:

序号字段名称字段类型大小
1idInt4
2addtime150
3shenqingbianhao150
4shenqingbiaotiDateTime8
5shenqingneirong150
6xiujiatianshuDateTime8
7xingchengchengshi150
8tujingchengshiDateTime8
9shenqingriqi150
10beizhuDateTime8
11xuehao150
12xueshengxingmingDateTime8
13touxiangDateTime8
14zhuanye150
15banjiDateTime8
16shouji150
17sfshDateTime8
18shhf150

xuesheng表:

序号字段名称字段类型大小
1idInt4
2addtime150
4xuehao150
5mima150
6xueshengxingmingDateTime8
7xingbie
8touxiangDateTime8
9zhuanye
10banjiDateTime8
11zhuzhishengfen
12shijiDateTime8
13xianquDateTime8
14shoujiDateTime8
15youxiangDateTime8

论文参考:

摘  要****

ABSTRACT****

目 录****

第1章 绪论****

1.1背景及意义

1.2 国内外研究概况

1.3 研究的内容

第2章 相关技术****

2.1 JAVA简介

2.2 MyEclipse开发环境

2.3 Tomcat服务器

2.4 MySQL数据库

2.5 Spring Boot框架

第3章 系统分析****

3.1 需求分析

3.2 系统可行性分析

3.2.1技术可行性:技术背景

3.2.2经济可行性

3.2.3操作可行性:

3.3 项目设计目标与原则

3.4系统流程分析

3.4.1操作流程

3.4.2添加信息流程

3.4.3删除信息流程

第4章 系统设计****

4.1 系统体系结构

4.2开发流程设计

4.3 数据库设计原则

4.4 数据表

第5章 系统详细设计****

5.1管理员功能模块

5.2学生前后台功能模块

第6章  系统测试****

6.1系统测试的目的

6.2系统测试方法

6.3功能测试

结  论****

致  谢****

参考文献

完整源码:

 大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻主页👇🏻👇🏻👇🏻

打卡 文章 更新 243/  365天