Skip to content
GitLab
Menu
Projects
Groups
Snippets
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
jinli gu
RuoYi Vue
Commits
28b9fbb4
Commit
28b9fbb4
authored
Jul 19, 2022
by
RuoYi
Browse files
优化多个相同角色数据导致权限SQL重复问题
parent
2c79dc90
Changes
1
Hide whitespace changes
Inline
Side-by-side
ruoyi-framework/src/main/java/com/ruoyi/framework/aspectj/DataScopeAspect.java
View file @
28b9fbb4
package
com.ruoyi.framework.aspectj
;
import
java.util.ArrayList
;
import
java.util.List
;
import
org.aspectj.lang.JoinPoint
;
import
org.aspectj.lang.annotation.Aspect
;
import
org.aspectj.lang.annotation.Before
;
...
...
@@ -79,15 +81,21 @@ public class DataScopeAspect
*
* @param joinPoint 切点
* @param user 用户
* @param userAlias 别名
* @param deptAlias 部门别名
* @param userAlias 用户别名
*/
public
static
void
dataScopeFilter
(
JoinPoint
joinPoint
,
SysUser
user
,
String
deptAlias
,
String
userAlias
)
{
StringBuilder
sqlString
=
new
StringBuilder
();
List
<
String
>
conditions
=
new
ArrayList
<
String
>();
for
(
SysRole
role
:
user
.
getRoles
())
{
String
dataScope
=
role
.
getDataScope
();
if
(
conditions
.
contains
(
dataScope
))
{
continue
;
}
if
(
DATA_SCOPE_ALL
.
equals
(
dataScope
))
{
sqlString
=
new
StringBuilder
();
...
...
@@ -121,6 +129,7 @@ public class DataScopeAspect
sqlString
.
append
(
StringUtils
.
format
(
" OR {}.dept_id = 0 "
,
deptAlias
));
}
}
conditions
.
add
(
dataScope
);
}
if
(
StringUtils
.
isNotBlank
(
sqlString
.
toString
()))
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment