专家推荐基于java Springboot+Vue+shiro前后端分离疫情防疫管理系统设计和实现2.0

本文主要是介绍专家推荐基于java Springboot+Vue+shiro前后端分离疫情防疫管理系统设计和实现2.0,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主要特性功能:

完全响应式布局(支持电脑、平板、手机等所有主流设备)

强大的一键生成功能(包括控制器、模型、视图、菜单等)

支持多数据源,简单配置即可实现切换。

支持按钮及数据权限,可自定义部门数据权限。

对常用js插件进行二次封装,使js代码变得简洁,更加易维护

完善的XSS防范及脚本过滤,彻底杜绝XSS攻击

Maven多项目依赖,模块及插件分项目,尽量松耦合,方便模块升级、增减模块。

国际化支持,服务端及客户端支持

完善的日志记录体系简单注解即可实现

支持服务监控,数据监控,缓存监控功能。

主要技术:java、springboot、springmvc、redis、shiro、vue、element、echarts、mysql等

视频效果演示 : 基于Springboot+Vue前后端分离疫情防疫管理系统设计和实.mp4https://www.bilibili.com/video/BV1tb4y1i7Lh 正在上传…重新上传取消​ https://www.bilibili.com/video/BV1tb4y1i7Lh

主要功能截图:

用户登录、输入账号密码进行验证和用户角色判断、不同角色不同菜单权限

系统首页:

疫情数据分布图模拟:

用户管理:

角色控制:

菜单权限:

每日健康打卡:

历史出行数据:

外出报备申请:

外出请假审核:

疫情通知公告:

疫情资料管理:

注销修改密码:

主要代码实现:

菜单列表处理和显示:

@Service("sysMenuService")
public class SysMenuServiceImpl extends ServiceImpl<SysMenuDao, SysMenuEntity> implements SysMenuService {@Autowiredprivate SysUserService sysUserService;@Autowiredprivate SysRoleMenuService sysRoleMenuService;@Overridepublic List<SysMenuEntity> queryListParentId(Long parentId, List<Long> menuIdList) {List<SysMenuEntity> menuList = queryListParentId(parentId);if(menuIdList == null){return menuList;}List<SysMenuEntity> userMenuList = new ArrayList<>();for(SysMenuEntity menu : menuList){if(menuIdList.contains(menu.getMenuId())){userMenuList.add(menu);}}return userMenuList;}@Overridepublic List<SysMenuEntity> queryListParentId(Long parentId) {return baseMapper.queryListParentId(parentId);}@Overridepublic List<SysMenuEntity> queryNotButtonList() {return baseMapper.queryNotButtonList();}@Overridepublic List<SysMenuEntity> getUserMenuList(Long userId) {//系统管理员,拥有最高权限if(userId == Constant.SUPER_ADMIN){return getAllMenuList(null);}//用户菜单列表List<Long> menuIdList = sysUserService.queryAllMenuId(userId);return getAllMenuList(menuIdList);}@Overridepublic void delete(Long menuId){//删除菜单this.removeById(menuId);//删除菜单与角色关联sysRoleMenuService.removeByMap(new MapUtils().put("menu_id", menuId));}/*** 获取所有菜单列表*/private List<SysMenuEntity> getAllMenuList(List<Long> menuIdList){//查询根菜单列表List<SysMenuEntity> menuList = queryListParentId(0L, menuIdList);//递归获取子菜单getMenuTreeList(menuList, menuIdList);return menuList;}/*** 递归*/private List<SysMenuEntity> getMenuTreeList(List<SysMenuEntity> menuList, List<Long> menuIdList){List<SysMenuEntity> subMenuList = new ArrayList<SysMenuEntity>();for(SysMenuEntity entity : menuList){//目录if(entity.getType() == Constant.MenuType.CATALOG.getValue()){entity.setList(getMenuTreeList(queryListParentId(entity.getMenuId(), menuIdList), menuIdList));}subMenuList.add(entity);}return subMenuList;}

shiro权限灵活控制到目录、菜单、按钮级别以及权限拦截。

@Bean("shiroFilter")public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {ShiroFilterFactoryBean shiroFilter = new ShiroFilterFactoryBean();shiroFilter.setSecurityManager(securityManager);//oauth过滤Map<String, Filter> filters = new HashMap<>();filters.put("oauth2", new OAuth2Filter());shiroFilter.setFilters(filters);Map<String, String> filterMap = new LinkedHashMap<>();filterMap.put("/webjars/**", "anon");filterMap.put("/druid/**", "anon");filterMap.put("/app/**", "anon");filterMap.put("/sys/login", "anon");filterMap.put("/swagger/**", "anon");filterMap.put("/v2/api-docs", "anon");filterMap.put("/swagger-ui.html", "anon");filterMap.put("/swagger-resources/**", "anon");filterMap.put("/captcha.jpg", "anon");filterMap.put("/aaa.txt", "anon");filterMap.put("/virtuel/**", "anon");filterMap.put("/**", "oauth2");shiroFilter.setFilterChainDefinitionMap(filterMap);return shiroFilter;}

登录模块的验证以及保存token到前端

/*** 登录*/@PostMapping("/sys/login")public Map<String, Object> login(@RequestBody SysLoginForm form)throws IOException {boolean captcha = sysCaptchaService.validate(form.getUuid(), form.getCaptcha());
//		if(!captcha){
//			return R.error("验证码不正确");
//		}//用户信息SysUserEntity user = sysUserService.queryByUserName(form.getUsername());//账号不存在、密码错误if(user == null || !user.getPassword().equals(new Sha256Hash(form.getPassword(), user.getSalt()).toHex())) {return R.error("账号或密码不正确");}//账号锁定if(user.getStatus() == 0){return R.error("账号已被锁定,请联系管理员");}//生成token,并保存到数据库R r = sysUserTokenService.createToken(user.getUserId());return r;}

主要数据表设计:

数据库名: renren-epidemic

文档版本: V1.0.0

文档描述: 数据库表设计描述

表clock

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

int

10

0

N

Y

2

name

varchar

255

0

Y

N

姓名

3

phone

varchar

255

0

Y

N

手机号

4

szd

varchar

255

0

Y

N

所在地

5

stzk

varchar

255

0

Y

N

身体状况

6

grjc

varchar

255

0

Y

N

是否和感染人员接触

7

bz

varchar

255

0

Y

N

8

create_time

datetime

19

0

Y

N

日期

9

tw

varchar

255

0

Y

N

表file

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

int

10

0

N

Y

2

path

varchar

255

0

Y

N

3

file_name

varchar

255

0

Y

N

4

file_type

varchar

255

0

Y

N

5

classify

varchar

255

0

Y

N

6

create_time

datetime

19

0

Y

N

7

create_by

varchar

255

0

Y

N

表go_out

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

int

10

0

N

Y

2

wc_time

datetime

19

0

Y

N

外出时间

3

wc_yy

varchar

255

0

Y

N

外出原因

4

wc_dd

varchar

255

0

Y

N

外出地点

5

username

varchar

255

0

Y

N

用户姓名

6

phone

varchar

255

0

Y

N

联系手机号码

7

bz

varchar

255

0

Y

N

备注说明

8

stu

varchar

255

0

Y

N

表info

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

int

10

0

N

Y

2

title

varchar

255

0

Y

N

3

content

longtext

2147483647

0

Y

N

4

create_time

datetime

19

0

Y

N

5

create_by

varchar

255

0

Y

N

6

bz

varchar

255

0

Y

N

表sys_captcha (系统验证码)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

uuid

char

36

0

N

Y

uuid

2

code

varchar

6

0

N

N

验证码

3

expire_time

datetime

19

0

Y

N

过期时间

表sys_config (系统配置信息表)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

bigint

20

0

N

Y

2

param_key

varchar

50

0

Y

N

key

3

param_value

varchar

2000

0

Y

N

value

4

status

tinyint

4

0

Y

N

1

状态   0:隐藏   1:显示

5

remark

varchar

500

0

Y

N

备注

表sys_log (系统日志)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

bigint

20

0

N

Y

2

username

varchar

50

0

Y

N

用户名

3

operation

varchar

50

0

Y

N

用户操作

4

method

varchar

200

0

Y

N

请求方法

5

params

varchar

5000

0

Y

N

请求参数

6

time

bigint

20

0

N

N

执行时长(毫秒)

7

ip

varchar

64

0

Y

N

IP地址

8

create_date

datetime

19

0

Y

N

创建时间

表sys_menu (菜单管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

menu_id

bigint

20

0

N

Y

2

parent_id

bigint

20

0

Y

N

父菜单ID,一级菜单为0

3

name

varchar

50

0

Y

N

菜单名称

4

url

varchar

200

0

Y

N

菜单URL

5

perms

varchar

500

0

Y

N

授权(多个用逗号分隔,如:user:list,user:create)

6

type

int

10

0

Y

N

类型   0:目录   1:菜单   2:按钮

7

icon

varchar

50

0

Y

N

菜单图标

8

order_num

int

10

0

Y

N

排序

表sys_oss (文件上传)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

bigint

20

0

N

Y

2

url

varchar

200

0

Y

N

URL地址

3

create_date

datetime

19

0

Y

N

创建时间

表sys_role (角色)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

role_id

bigint

20

0

N

Y

2

role_name

varchar

100

0

Y

N

角色名称

3

remark

varchar

100

0

Y

N

备注

4

create_user_id

bigint

20

0

Y

N

创建者ID

5

create_time

datetime

19

0

Y

N

创建时间

表sys_role_menu (角色与菜单对应关系)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

bigint

20

0

N

Y

2

role_id

bigint

20

0

Y

N

角色ID

3

menu_id

bigint

20

0

Y

N

菜单ID

表sys_user (系统用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_id

bigint

20

0

N

Y

2

username

varchar

50

0

N

N

用户名

3

password

varchar

100

0

Y

N

密码

4

salt

varchar

20

0

Y

N

5

email

varchar

100

0

Y

N

邮箱

6

mobile

varchar

100

0

Y

N

手机号

7

status

tinyint

4

0

Y

N

状态  0:禁用   1:正常

8

create_user_id

bigint

20

0

Y

N

创建者ID

9

create_time

datetime

19

0

Y

N

创建时间

表sys_user_role (用户与角色对应关系)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

bigint

20

0

N

Y

2

user_id

bigint

20

0

Y

N

用户ID

3

role_id

bigint

20

0

Y

N

角色ID

表sys_user_token (系统用户Token)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_id

bigint

20

0

N

Y

2

token

varchar

100

0

N

N

token

3

expire_time

datetime

19

0

Y

N

过期时间

4

update_time

datetime

19

0

Y

N

更新时间

表thm

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

int

10

0

N

Y

2

username

varchar

255

0

Y

N

3

cx_time

datetime

19

0

Y

N

4

place

varchar

255

0

Y

N

5

bz

varchar

255

0

Y

N

6

mobile

varchar

255

0

Y

N

表towork_apply

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

id

int

10

0

N

Y

2

title

varchar

255

0

Y

N

3

content

varchar

255

0

Y

N

4

apply_user

varchar

255

0

Y

N

5

apply_time

datetime

19

0

Y

N

6

bz

varchar

255

0

Y

N

7

stu

varchar

255

0

Y

N

这篇关于专家推荐基于java Springboot+Vue+shiro前后端分离疫情防疫管理系统设计和实现2.0的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588701

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template