基于Springboot+Vue+shiro+redis实现前后端分离疫情防疫管理系统设计和实现2.0
Posted java李杨勇
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于Springboot+Vue+shiro+redis实现前后端分离疫情防疫管理系统设计和实现2.0相关的知识,希望对你有一定的参考价值。
目录
🍅 作者主页:Java李杨勇
🍅 简介:Java领域优质创作者🏆、【java李杨勇】公号作者✌ 简历模板、学习资料、面试题库【关注我,都给你】
🍅文末获取源码联系🍅
主要特性功能:
完全响应式布局(支持电脑、平板、手机等所有主流设备)
强大的一键生成功能(包括控制器、模型、视图、菜单等)
支持多数据源,简单配置即可实现切换。
支持按钮及数据权限,可自定义部门数据权限。
对常用js插件进行二次封装,使js代码变得简洁,更加易维护
完善的XSS防范及脚本过滤,彻底杜绝XSS攻击
Maven多项目依赖,模块及插件分项目,尽量松耦合,方便模块升级、增减模块。
国际化支持,服务端及客户端支持
完善的日志记录体系简单注解即可实现
支持服务监控,数据监控,缓存监控功能。主要技术:java、springboot、springmvc、redis、shiro、vue、element、echarts、mysql等
视频效果演示 :基于Springboot+Vue前后端分离疫情防疫管理系统设计和实.mp4https://www.bilibili.com/video/BV1tb4y1i7Lhhttps://www.bilibili.com/video/BV1tb4y1i7Lh
主要功能截图:
用户登录、输入账号密码进行验证和用户角色判断、不同角色不同菜单权限
系统首页:
疫情数据分布图模拟:
用户管理:
角色控制:
菜单权限:
每日健康打卡:
历史出行数据:
外出报备申请:
外出请假审核:
疫情通知公告:
疫情资料管理:
注销修改密码:
主要代码实现:
菜单列表处理和显示:
@Service("sysMenuService")
public class SysMenuServiceImpl extends ServiceImpl<SysMenuDao, SysMenuEntity> implements SysMenuService
@Autowired
private SysUserService sysUserService;
@Autowired
private SysRoleMenuService sysRoleMenuService;
@Override
public 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;
@Override
public List<SysMenuEntity> queryListParentId(Long parentId)
return baseMapper.queryListParentId(parentId);
@Override
public List<SysMenuEntity> queryNotButtonList()
return baseMapper.queryNotButtonList();
@Override
public List<SysMenuEntity> getUserMenuList(Long userId)
//系统管理员,拥有最高权限
if(userId == Constant.SUPER_ADMIN)
return getAllMenuList(null);
//用户菜单列表
List<Long> menuIdList = sysUserService.queryAllMenuId(userId);
return getAllMenuList(menuIdList);
@Override
public 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 | 新年福利大放送-基于kotlin+springboot+vue+shiro后台管理项目开源啦 基于前后端分离的授权及认证(Shiro-SpringBoot-Vue) 基于java Springboot+Vue+shiro前后端分离疫情防疫管理系统设计和实现2.0 基于Springboot+Vue+shiro+redis实现前后端分离疫情防疫管理系统设计和实现2.0 |