我是靠谱客的博主 和谐蛋挞,最近开发中收集的这篇文章主要介绍若依的数据隔离${params.dataScope},觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、在(系统管理-角色管理)设置需要数据权限的角色目前支持以下几种权限

全部数据权限
自定数据权限
部门数据权限
部门及以下数据权限
仅本人数据权限2、在需要数据权限控制方法上添加@DataScope注解,其中d和u用来表示表的别名
// 部门数据权限注解
@DataScope(deptAlias = “u”)
// 部门及用户权限注解
@DataScope(deptAlias = “d”, userAlias = “u”)
3、在mybatis查询底部标签添加数据范围过滤

${params.dataScope}
用户管理(未过滤数据权限的情况):

select u.user_id, u.dept_id, u.login_name, u.user_name, u.email
, u.phonenumber, u.password, u.sex, u.avatar, u.salt
, u.status, u.del_flag, u.login_ip, u.login_date, u.create_by
, u.create_time, u.remark, d.dept_name
from sys_user u
left join sys_dept d on u.dept_id = d.dept_id
where u.del_flag = ‘0’
用户管理(已过滤数据权限的情况):

select u.user_id, u.dept_id, u.login_name, u.user_name, u.email
, u.phonenumber, u.password, u.sex, u.avatar, u.salt
, u.status, u.del_flag, u.login_ip, u.login_date, u.create_by
, u.create_time, u.remark, d.dept_name
from sys_user u
left join sys_dept d on u.dept_id = d.dept_id
where u.del_flag = ‘0’
and u.dept_id in (
select dept_id
from sys_role_dept
where role_id = 2
)
结果很明显,我们多了如下语句。通过角色部门表(sys_role_dept)完成了数据权限过滤

and u.dept_id in (
select dept_id
from sys_role_dept
where role_id = 2
)

最后

以上就是和谐蛋挞为你收集整理的若依的数据隔离${params.dataScope}的全部内容,希望文章能够帮你解决若依的数据隔离${params.dataScope}所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部