基于SpringBoot的校园疫情防控系统设计与实现

Posted 爱coding的李同学

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于SpringBoot的校园疫情防控系统设计与实现相关的知识,希望对你有一定的参考价值。

1.概述

校园疫情防控系统的开发运用java技术、springboot框架,MIS的总体思想,以及mysql等技术的支持下共同完成了该系统的开发,实现了校园疫情防控管理的信息化,使用户体验到校园疫情防控管理,管理员管理操作将更加方便,实现目标。

校园疫情防控系统的需求和管理上的不断提升,校园疫情防控系统的潜力将无限扩大,校园疫情防控系统在业界被广泛关注,本网站及对此进行总体分析,将校园疫情防控信息管理的发展提供参考。校园疫情防控系统对个人或都有着明显的带动效应,尤其对当地企业、公司的管理帮助更大。

根据现有的模块,除管理员对系统所有的信息进行管理;另外系统前端还需要:首页、疫情动态、知识信息、防疫教育、交流论坛、疫情公告、个人中心、后台管理等内容进行配合管理。

2.开发技术介绍

2.1 Springboot框架

SpringBoot是一个全新开源的轻量级框架。基于Spring4.0设计,其不仅继承了Spring框架原来有的优秀特性,而且还通过简化配置文件来进一步简化了Spring应用的整个搭建以及开发过程。另外在原本的Spring中由于随着项目的扩大导入的jar包数量越来越大,随之出现了jar包版本之间的兼容性问题,而此时SpringBoot通过集成大量的框架使得依赖包的版本冲突,以及引用的不稳定性问题得到了很好的解决。
SpringBoot可以看做是Spring的加强版本,但实质上都是Spring的相关技术,有了这些优秀的开源框架,程序员在开发过程中将事半功倍。

2.2 Java技术

Java 语言比较容易理解,而且也容易学习和上手,其语法与C语言和C++语言很相似,它可以自动的处理废料,而且不会受到内存的影响。

Java 程序被编译后形成的class 文件,这样就能够实现在多系统中正常运行。Java语言支持多个线程同吋执行,Java程序所需要的类能够动态的或者通过网络被载入到运行环境。Java开发工具支持JavaJDK7\\8,开发集成环境IDE为Eclipse。

2.3 Mysql数据库介绍

Mysql的特点是支持多线程,能方便的对系统资源充分利用,有效提高速度,还提供多种方式途径来对数据库进行连接;Mysql的功能相对弱小、规模也小,但本系统要求不高,Mysql完全可以满足本系统使用。

3.系统设计

3.1 功能结构

为了更好的去理清本系统整体思路,对该系统以结构图的形式表达出来,设计实现该校园疫情防控系统的功能结构图如下所示:

3.2 数据库设计

3.2.1 数据库E/R图

ER图是由实体及其关系构成的图,通过E/R图可以清楚地描述系统涉及到的实体之间的相互关系。在系统中对一些主要的几个关键实体如下图:

(1)知识信息E/R图如下所示:

(2)疫情动态E/R图如下所示:

(3)学生注册E/R图如下所示:

3.2.2 数据库设计

此处只展示部分数据库表。

核酸报告

交流论坛

防疫教育

知识信息评论表

4. 系统功能实现

4.1系统功能模块

校园疫情防控系统,在系统首页可以查看首页、疫情动态、知识信息、防疫教育、交流论坛、疫情公告、个人中心、后台管理等内容,并进行详细操作;如图所示:

防疫教育,在防疫教育页面可以查看教育标题、 教育类型、教育简介等内容进行评论或收藏等操作;如图:
在这里插入图片描述

4.2 后台功能模块

后台登录,管理员和学生进入系统前在登录页面根据要求填写用户名和密码,选择角色等信息,点击登录进行登录操作,如图:

4.2.1 管理员功能

管理员登录系统后,可以对首页、个人中心、学生管理、疫情动态管理、知识信息管理、防疫教育管理、健康打卡管理、请假申请管理、出校登记管理、入校登记管理、核酸报告管理、交流论坛、系统管理等功能进行相应的操作管理,如图:

学生管理,在学生管理页面可以对索引、学号、姓名、性别、手机、班级、头像等内容进行详情、修改或删除等操作,如图:

疫情动态管理,在疫情动态管理管理页面可以对索引、城市地区、新增病例、累计确诊、治愈人数、死亡人数、登记时间等内容进行详情、查看评论、修改或删除等操作,如图:

健康打卡管理,在健康打卡管理页面可以对索引、学号、姓名、班级、身体情况、体温、是否发热、是否咳嗽、接触史、打卡时间、打卡地点、健康码等内容进行详情或删除等操作;如图:

出校登记管理,在出校登记管理页面中可以对索引、姓名、性别、类型、出校时间、健康码等内容进行详情、修改或删除等操作,如图:

4.2.2学生功能

学生注册,通过填写学号、密码、确认密码、姓名、手机、班级等内容进行注册,如图:

学生登录进入系统可以对首页、个人中心、健康打卡管理、请假申请管理、核酸报告管理等功能进行相应操作,如图:
健康打卡管理,在健康打卡管理页面中可以对索引、学号、姓名、班级、身体情况、体温、是否发热、是否咳嗽、接触史、打卡时间、打卡地点、健康码等内容进行详情、修改或删除等操作,如图:

5. 部分代码展示

5.1 用户登录

/**
 * 登录相关
 */
@RequestMapping("users")
@RestController
public class UserController
	
	@Autowired
	private UserService userService;
	
	@Autowired
	private TokenService tokenService;

	/**
	 * 登录
	 */
	@IgnoreAuth
	@PostMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) 
		UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) 
			return R.error("账号或密码不正确");
		
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UserEntity user)
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) 
    		return R.error("用户已存在");
    	
        userService.insert(user);
        return R.ok();
    

	/**
	 * 退出
	 */
	@GetMapping(value = "logout")
	public R logout(HttpServletRequest request) 
		request.getSession().invalidate();
		return R.ok("退出成功");
	

5.2 健康打卡

@RestController
@RequestMapping("/jiankangdaka")
public class JiankangdakaController 
    @Autowired
    private JiankangdakaService jiankangdakaService;


    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,JiankangdakaEntity jiankangdaka,
		HttpServletRequest request)
		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("xuesheng")) 
			jiankangdaka.setXuehao((String)request.getSession().getAttribute("username"));
		
        EntityWrapper<JiankangdakaEntity> ew = new EntityWrapper<JiankangdakaEntity>();
		PageUtils page = jiankangdakaService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiankangdaka), params), params));

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

6. 项目总结

通过对校园疫情防控管理系统的开发,让我深刻明白开发一个程序软件需要经历的流程,当确定要开发一个系统的时候,对其功能进行合理的需求分析,然后才是程序软件的功能的框架设计,数据库的实体与数据表设计,程序软件的功能详细界面实现,以及程序的功能测试等进行全方位的细致考虑,虽然在此过程中,各个环节都遇到了大大小小的困难,但是通过对这些问题进行反复的分析,深入的思考,借助各种相关文献资料提供的方法与解决思路成功解决面临的各个问题,最后成功的让系统得以正常运行。商毕业设计管理系统在功能上面是基本可以满足用户对系统的操作,但是这个程序软件也有许多方面是不足的,因此,在下一个时间阶段,有几点需要改进的地方需要提出来,它们分别是:

(1)操作页面可以满足用户简易操作的要求,但是在页面多样化设计层面上需要把一些比较丰富的设计结构考虑进来。

(2)程序软件的总体安全性能需要优化,例如程序的退出安全性,以及程序的并发性等问题都需要进行安全性升级。

(3)需要对程序的数据结构方面,程序的代码方面等进行优化,让运行起来的程序可以保持稳定运行,也让程序能够保证短时间内处理相关事务,节省处理事务的时间,提高事务处理的效率,同时对服务器上资源占用的比例进行降低。

7.源码获取

想要源码的小伙伴,大家点赞、收藏、关注、私信啦。谢谢各位大大。

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

🍅 作者简介:CSDN特邀作者✌、博客专家✌、java领域优质创作者💪

🍅关注公众号【java李杨勇】  简历模板、学习资料、面试题库等都给你💪

🍅文末获取源码联系🍅

🍅新星计划·第三季【Java】赛道的报名入口!下一个新星就是你🍅

前言介绍:

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

功能设计:

技术可行性:技术背景     

本企业网站在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功能测试

  

  

参考文献

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

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

疫情防控|Springboot+小程序+校园疫情防控系统设计与实现

疫情防控|Springboot+小程序+校园疫情防控系统设计与实现

疫情防控|Springboot+小程序+校园疫情防控系统设计与实现

计算机毕业设计springboot+vue+elementUI校园疫情防控系统