likes
comments
collection
share

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

作者站长头像
站长
· 阅读数 151

主要特性功能:

完全响应式布局(支持电脑、平板、手机等所有主流设备) 强大的一键生成功能(包括控制器、模型、视图、菜单等) 支持多数据源,简单配置即可实现切换。 支持按钮及数据权限,可自定义部门数据权限。 对常用js插件进行二次封装,使js代码变得简洁,更加易维护 完善的XSS防范及脚本过滤,彻底杜绝XSS攻击 Maven多项目依赖,模块及插件分项目,尽量松耦合,方便模块升级、增减模块。 国际化支持,服务端及客户端支持 完善的日志记录体系简单注解即可实现 支持服务监控,数据监控,缓存监控功能。

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

视频效果演示 # 基于Springboot+Vue前后端分离疫情防疫管理系统设计和实现.mp4

主要功能截图:

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

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

系统首页:  

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

疫情数据分布图模拟:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

用户管理:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

角色控制:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

菜单权限:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

每日健康打卡:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

 一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

历史出行数据:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

外出报备申请:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

外出请假审核:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

 一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

疫情通知公告:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

疫情资料管理:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

 一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密

注销修改密码:

一个基于Springboot+Vue+shiro+redis前后端分离疫情防疫管理系统的详细设计​ 用户登录、输入账号密​主要代码实现:

菜单列表处理和显示:

@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

编号名称数据类型长度小数位允许空值主键默认值说明
1idint100NY
2namevarchar2550YN姓名
3phonevarchar2550YN手机号
4szdvarchar2550YN所在地
5stzkvarchar2550YN身体状况
6grjcvarchar2550YN是否和感染人员接触
7bzvarchar2550YN
8create_timedatetime190YN日期
9twvarchar2550YN

表file

编号名称数据类型长度小数位允许空值主键默认值说明
1idint100NY
2pathvarchar2550YN
3file_namevarchar2550YN
4file_typevarchar2550YN
5classifyvarchar2550YN
6create_timedatetime190YN
7create_byvarchar2550YN

表go_out

编号名称数据类型长度小数位允许空值主键默认值说明
1idint100NY
2wc_timedatetime190YN外出时间
3wc_yyvarchar2550YN外出原因
4wc_ddvarchar2550YN外出地点
5usernamevarchar2550YN用户姓名
6phonevarchar2550YN联系手机号码
7bzvarchar2550YN备注说明
8stuvarchar2550YN

表info

编号名称数据类型长度小数位允许空值主键默认值说明
1idint100NY
2titlevarchar2550YN
3contentlongtext21474836470YN
4create_timedatetime190YN
5create_byvarchar2550YN
6bzvarchar2550YN

表sys_captcha (系统验证码)

编号名称数据类型长度小数位允许空值主键默认值说明
1uuidchar360NYuuid
2codevarchar60NN验证码
3expire_timedatetime190YN过期时间

表sys_config (系统配置信息表)

编号名称数据类型长度小数位允许空值主键默认值说明
1idbigint200NY
2param_keyvarchar500YNkey
3param_valuevarchar20000YNvalue
4statustinyint40YN1状态   0:隐藏   1:显示
5remarkvarchar5000YN备注

表sys_log (系统日志)

编号名称数据类型长度小数位允许空值主键默认值说明
1idbigint200NY
2usernamevarchar500YN用户名
3operationvarchar500YN用户操作
4methodvarchar2000YN请求方法
5paramsvarchar50000YN请求参数
6timebigint200NN执行时长(毫秒)
7ipvarchar640YNIP地址
8create_datedatetime190YN创建时间

表sys_menu (菜单管理)

编号名称数据类型长度小数位允许空值主键默认值说明
1menu_idbigint200NY
2parent_idbigint200YN父菜单ID,一级菜单为0
3namevarchar500YN菜单名称
4urlvarchar2000YN菜单URL
5permsvarchar5000YN授权(多个用逗号分隔,如:user:list,user:create)
6typeint100YN类型   0:目录   1:菜单   2:按钮
7iconvarchar500YN菜单图标
8order_numint100YN排序

表sys_oss (文件上传)

编号名称数据类型长度小数位允许空值主键默认值说明
1idbigint200NY
2urlvarchar2000YNURL地址
3create_datedatetime190YN创建时间

表sys_role (角色)

编号名称数据类型长度小数位允许空值主键默认值说明
1role_idbigint200NY
2role_namevarchar1000YN角色名称
3remarkvarchar1000YN备注
4create_user_idbigint200YN创建者ID
5create_timedatetime190YN创建时间

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

编号名称数据类型长度小数位允许空值主键默认值说明
1idbigint200NY
2role_idbigint200YN角色ID
3menu_idbigint200YN菜单ID

表sys_user (系统用户)

编号名称数据类型长度小数位允许空值主键默认值说明
1user_idbigint200NY
2usernamevarchar500NN用户名
3passwordvarchar1000YN密码
4saltvarchar200YN
5emailvarchar1000YN邮箱
6mobilevarchar1000YN手机号
7statustinyint40YN状态  0:禁用   1:正常
8create_user_idbigint200YN创建者ID
9create_timedatetime190YN创建时间

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

编号名称数据类型长度小数位允许空值主键默认值说明
1idbigint200NY
2user_idbigint200YN用户ID
3role_idbigint200YN角色ID

表sys_user_token (系统用户Token)

编号名称数据类型长度小数位允许空值主键默认值说明
1user_idbigint200NY
2tokenvarchar1000NNtoken
3expire_timedatetime190YN过期时间
4update_timedatetime190YN更新时间

表thm

编号名称数据类型长度小数位允许空值主键默认值说明
1idint100NY
2usernamevarchar2550YN
3cx_timedatetime190YN
4placevarchar2550YN
5bzvarchar2550YN
6mobilevarchar2550YN

表towork_apply

编号名称数据类型长度小数位允许空值主键默认值说明
1idint100NY
2titlevarchar2550YN
3contentvarchar2550YN
4apply_uservarchar2550YN
5apply_timedatetime190YN
6bzvarchar2550YN
7stuvarchar2550YN

大家点赞、收藏、关注、评论啦 、 打卡 文章 更新 112/  365天

转载自:https://juejin.cn/post/7039117274413793293
评论
请登录