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

举报
Java李杨勇 发表于 2022/03/31 21:52:43 2022/03/31
【摘要】 前言介绍:      随着社会的快速发展,计算机的影响是全面且深入的。学校管理水平的不断提高,日常生活中学生对校园疫情防控方面的要求也在不断提高,学生的人数更是不断增加,使得校园疫情防控系统的开发成为必需而且紧迫的事情。校园疫情防控系统主要是借助计算机,通过对校园疫情防控系统所需的信息管理,增加学生的选择,同时也方便对广大学生信息的及时查询、修改以及对学生信息的及时了解。校园疫情防控系统对学...

前言介绍:

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

功能设计:

技术可行性:技术背景     

本企业网站在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表:

序号

字段名称

字段类型

大小

1

id

Int

4

2

username


150

3

pwd


150

4

cx


150

5

addtime

DateTime

8

churudengji表:

序号

字段名称

字段类型

大小

1

id

Int

4

2

addtime


150

3

dengjibiaoti


150

4

dengjileixing

DateTime

8

5

dengjineirong


150

6

dengjishijian

DateTime

8

7

beizhu


150

8

xuehao

DateTime

8

9

xueshengxingming


150

10


xingbie

DateTime

8

11

touxiang


150

12

shishitiwen

DateTime

8

13

shouji



14

banji

DateTime

8

15

zhuanye



16

sfsh

DateTime

150

17

shhf



xiujiashenqing表:

序号

字段名称

字段类型

大小

1

id

Int

4

2

addtime


150

3

shenqingbianhao


150

4

shenqingbiaoti

DateTime

8

5

shenqingneirong


150

6

xiujiatianshu

DateTime

8

7

xingchengchengshi


150

8

tujingchengshi

DateTime

8

9

shenqingriqi


150

10


beizhu

DateTime

8

11

xuehao


150

12

xueshengxingming

DateTime

8

13

touxiang

DateTime

8

14

zhuanye


150

15

banji

DateTime

8

16

shouji


150

17

sfsh

DateTime

8

18

shhf


150

xuesheng表:

序号

字段名称

字段类型

大小

1

id

Int

4

2

addtime


150

4

xuehao


150

5

mima


150

6

xueshengxingming

DateTime

8

7

xingbie



8

touxiang

DateTime

8

9

zhuanye



10

banji

DateTime

8

11

zhuzhishengfen



12

shiji

DateTime

8

13

xianqu

DateTime

8

14

shouji

DateTime

8

15

youxiang

DateTime

8

论文参考:

  

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天

 精彩专栏推荐订阅下方专栏👇🏻👇🏻👇🏻👇🏻

Java项目精品实战案例《100套》

web前端期末大作业网页实战《100套》

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。