spring-boot-plus V1.4.0发布 集成用户角色权限部门管理
RBAC用户角色权限
用户角色权限部门管理核心接口介绍
Shiro权限配置
- Shiro权限配置
数据库模型图
- spring-boot-plus初始化SQL下载
获取验证码
- 可配置是否启用验证码
- 默认未启用
- 如已启用验证码校验,登陆时,需传入verifyToken和code
验证码演示
spring-boot-plus: # 是否启用ansi控制台输出有颜色的字体 enable-ansi: true # 是否启用验证码 enable-verify-code: trueenable-verify-code 设置为 true 启用验证码验证
两种方式获取验证码
验证码后台保存在Redis中,过期时间默认为5分钟
方式一:
http://localhost:8888/verificationCode/getImage Response Headers HTTP 200 verifyToken: 6515b4b798ce49e68b1e40f98ff8eb19输出图片流到浏览器,验证码token输出到响应头
方式二:
http://localhost:8888/verificationCode/getBase64Image { "code": 200, "msg": "操作成功", "success": true, "data": { "image": "", "verifyToken": "42ba8abde7bc47b2b1397b4d6676956a" }, "time": "2019-11-01 22:40:37" }获取Base64编码图片和验证码token
系统用户登陆
- POST请求,Content-Type: application/json
- 请求参数
注意
- 如果没有启用验证码登陆,则只需传入username和password
- 前端应将密码加密后进行传输
登陆成功
- 返回登陆用户信息:部门/角色/权限
- 返回用户token
- token默认失效时间为1个小时
- 设置JWT Token失效时间
- 后台使用Redis缓存登陆用户信息
- redis key
其它需要授权访问的接口,请求头需携带token
部门树形列表
- 部门可以设置为N级,后台使用递归将部门列表转换为树形列表
- SysDepartmentServiceImpl
- 前端JSON结构
角色管理
设置角色权限
- 核心代码,删除角色权限,新增角色权限
- 求集合的差集
- SysRolePermissionServiceImpl
权限管理
权限树形列表
- 用户设置角色权限时,选择权限菜单
- 权限分为菜单和功能权限
- 后台获取三层权限树
- 前端JSON格式
权限编码列表
{ "code": 200, "msg": "操作成功", "success": true, "data": [ "system:management", "system:management", "sys:user:management", "sys:user:management", "sys:role:management", "sys:permission:management", "sys:department:management", "sys:user:add", "sys:user:add", "sys:user:update", "sys:user:update", "sys:user:delete", "sys:user:delete", "sys:user:info", "sys:user:info", "sys:user:page", "sys:user:page", "sys:user:update:password", "sys:user:update:head", "sys:role:add", "sys:role:update", "sys:role:delete", "sys:role:info", "sys:role:page", "sys:permission:add", "sys:permission:update", "sys:permission:delete", "sys:permission:info", "sys:permission:page", "sys:permission:all:menu:list", "sys:permission:all:menu:tree", "sys:permission:menu:list", "sys:permission:menu:tree", "sys:permission:codes", "sys:department:update", "sys:department:delete", "sys:department:info", "sys:department:page" ], "time": "2019-11-02 00:32:17" }返回当前用户所有的权限编码,方便前端展示导航菜单和功能按钮
注意
- 使用Shiro注解@RequiresPermissions进行controller方法权限过滤
- 生成代码时,可配置生成RequiresPermissions注解
- 生成或新增的controller方法,需要进行权限管理,需要到sys_permission表新增权限编码记录,并给相应角色赋予权限