基于SpringBoot +Shiro+Redis +vue的物流管理系统

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于SpringBoot +Shiro+Redis +vue的物流管理系统相关的知识,希望对你有一定的参考价值。

参考技术A

一、项目简介

基于SpringBoot +Shiro+Redis +vue的物流管理系统。

二、实现功能

三、技术选型

SpringBoot 

Shiro

Redis 

vue

四、界面展示


五、源码地址

私信回复:物流管理




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

目录  

研究背景

主要特性功能:

视频效果演示 :

主要功能截图:

系统首页:  

疫情数据分布图模拟:

用户管理:

角色控制:

菜单权限:

每日健康打卡:

历史出行数据:

外出报备申请:

外出请假审核:

疫情通知公告:

疫情资料管理:

注销修改密码:

​主要代码实现:

主要数据表设计:

表clock

表file

表go_out

表info

表sys_captcha (系统验证码)

表sys_config (系统配置信息表)

表sys_log (系统日志)

表sys_menu (菜单管理)

表sys_oss (文件上传)

表sys_role (角色)

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

表sys_user (系统用户)

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

表sys_user_token (系统用户Token)

表thm

表towork_apply

 获取源码联系:


🍅 作者主页: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

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

文章目录一览表

基于Springboot实现的固废物管理系统

springboot+shiro+redis(单机redis版)整合教程-续(添加动态角色权限控制)

Shiro整合Springboot缓存之Redis实现

Springboot学习SpringBoot集成Shiro前后端分离使用redis做缓存个人博客搭建

(c)2006-2024 SYSTEM All Rights Reserved IT常识