ソースを参照

优化权限认证注解

RuoYi 4 年 前
コミット
d8da1b796c
共有29 個のファイルを変更した850 個の追加401 個の削除を含む
  1. 16 0
      ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/exception/auth/NotLoginException.java
  2. 23 0
      ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/exception/auth/NotPermissionException.java
  3. 23 0
      ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/exception/auth/NotRoleException.java
  4. 4 2
      ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/utils/SecurityUtils.java
  5. 20 0
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/Logical.java
  6. 0 46
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/PreAuthorize.java
  7. 18 0
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/RequiresLogin.java
  8. 27 0
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/RequiresPermissions.java
  9. 26 0
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/RequiresRoles.java
  10. 97 225
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/aspect/PreAuthorizeAspect.java
  11. 329 0
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/auth/AuthLogic.java
  12. 127 0
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/auth/AuthUtil.java
  13. 18 6
      ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/handler/GlobalExceptionHandler.java
  14. 12 12
      ruoyi-modules/ruoyi-gen/src/main/java/com/ruoyi/gen/controller/GenController.java
  15. 7 7
      ruoyi-modules/ruoyi-gen/src/main/resources/vm/java/controller.java.vm
  16. 9 9
      ruoyi-modules/ruoyi-job/src/main/java/com/ruoyi/job/controller/SysJobController.java
  17. 6 6
      ruoyi-modules/ruoyi-job/src/main/java/com/ruoyi/job/controller/SysJobLogController.java
  18. 7 7
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysConfigController.java
  19. 7 7
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysDeptController.java
  20. 7 7
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysDictDataController.java
  21. 8 8
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysDictTypeController.java
  22. 5 5
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysLogininforController.java
  23. 6 6
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysMenuController.java
  24. 6 6
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysNoticeController.java
  25. 5 5
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysOperlogController.java
  26. 7 7
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysPostController.java
  27. 15 15
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysRoleController.java
  28. 12 12
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java
  29. 3 3
      ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserOnlineController.java

+ 16 - 0
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/exception/auth/NotLoginException.java

@@ -0,0 +1,16 @@
1
+package com.ruoyi.common.core.exception.auth;
2
+
3
+/**
4
+ * 未能通过的登录认证异常
5
+ * 
6
+ * @author ruoyi
7
+ */
8
+public class NotLoginException extends RuntimeException
9
+{
10
+    private static final long serialVersionUID = 1L;
11
+
12
+    public NotLoginException(String message)
13
+    {
14
+        super(message);
15
+    }
16
+}

+ 23 - 0
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/exception/auth/NotPermissionException.java

@@ -0,0 +1,23 @@
1
+package com.ruoyi.common.core.exception.auth;
2
+
3
+import org.apache.commons.lang3.StringUtils;
4
+
5
+/**
6
+ * 未能通过的权限认证异常
7
+ * 
8
+ * @author ruoyi
9
+ */
10
+public class NotPermissionException extends RuntimeException
11
+{
12
+    private static final long serialVersionUID = 1L;
13
+
14
+    public NotPermissionException(String permission)
15
+    {
16
+        super(permission);
17
+    }
18
+
19
+    public NotPermissionException(String[] permissions)
20
+    {
21
+        super(StringUtils.join(permissions, ","));
22
+    }
23
+}

+ 23 - 0
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/exception/auth/NotRoleException.java

@@ -0,0 +1,23 @@
1
+package com.ruoyi.common.core.exception.auth;
2
+
3
+import org.apache.commons.lang3.StringUtils;
4
+
5
+/**
6
+ * 未能通过的角色认证异常
7
+ * 
8
+ * @author ruoyi
9
+ */
10
+public class NotRoleException extends RuntimeException
11
+{
12
+    private static final long serialVersionUID = 1L;
13
+
14
+    public NotRoleException(String role)
15
+    {
16
+        super(role);
17
+    }
18
+
19
+    public NotRoleException(String[] roles)
20
+    {
21
+        super(StringUtils.join(roles, ","));
22
+    }
23
+}

+ 4 - 2
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/utils/SecurityUtils.java

@@ -42,18 +42,20 @@ public class SecurityUtils
42
      */
42
      */
43
     public static String getToken(HttpServletRequest request)
43
     public static String getToken(HttpServletRequest request)
44
     {
44
     {
45
+        // 从header获取token标识
45
         String token = request.getHeader(SecurityConstants.TOKEN_AUTHENTICATION);
46
         String token = request.getHeader(SecurityConstants.TOKEN_AUTHENTICATION);
46
         return replaceTokenPrefix(token);
47
         return replaceTokenPrefix(token);
47
     }
48
     }
48
 
49
 
49
     /**
50
     /**
50
-     * 替换token前缀
51
+     * 裁剪token前缀
51
      */
52
      */
52
     public static String replaceTokenPrefix(String token)
53
     public static String replaceTokenPrefix(String token)
53
     {
54
     {
55
+        // 如果前端设置了令牌前缀,则裁剪掉前缀
54
         if (StringUtils.isNotEmpty(token) && token.startsWith(SecurityConstants.TOKEN_PREFIX))
56
         if (StringUtils.isNotEmpty(token) && token.startsWith(SecurityConstants.TOKEN_PREFIX))
55
         {
57
         {
56
-            token = token.replace(SecurityConstants.TOKEN_PREFIX, "");
58
+            token = token.replaceFirst(SecurityConstants.TOKEN_PREFIX, "");
57
         }
59
         }
58
         return token;
60
         return token;
59
     }
61
     }

+ 20 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/Logical.java

@@ -0,0 +1,20 @@
1
+package com.ruoyi.common.security.annotation;
2
+
3
+/**
4
+ * 权限注解的验证模式
5
+ * 
6
+ * @author ruoyi
7
+ *
8
+ */
9
+public enum Logical
10
+{
11
+    /**
12
+     * 必须具有所有的元素
13
+     */
14
+    AND,
15
+
16
+    /**
17
+     * 只需具有其中一个元素
18
+     */
19
+    OR
20
+}

+ 0 - 46
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/PreAuthorize.java

@@ -1,46 +0,0 @@
1
-package com.ruoyi.common.security.annotation;
2
-
3
-import java.lang.annotation.ElementType;
4
-import java.lang.annotation.Retention;
5
-import java.lang.annotation.RetentionPolicy;
6
-import java.lang.annotation.Target;
7
-
8
-/**
9
- * 权限注解
10
- * 
11
- * @author ruoyi
12
- */
13
-@Target({ ElementType.TYPE, ElementType.METHOD })
14
-@Retention(RetentionPolicy.RUNTIME)
15
-public @interface PreAuthorize
16
-{
17
-    /**
18
-     * 验证用户是否具备某权限
19
-     */
20
-    public String hasPermi() default "";
21
-
22
-    /**
23
-     * 验证用户是否不具备某权限,与 hasPermi逻辑相反
24
-     */
25
-    public String lacksPermi() default "";
26
-
27
-    /**
28
-     * 验证用户是否具有以下任意一个权限
29
-     */
30
-    public String[] hasAnyPermi() default {};
31
-
32
-    /**
33
-     * 判断用户是否拥有某个角色
34
-     */
35
-    public String hasRole() default "";
36
-
37
-    /**
38
-     * 验证用户是否不具备某角色,与 isRole逻辑相反
39
-     */
40
-    public String lacksRole() default "";
41
-
42
-    /**
43
-     * 验证用户是否具有以下任意一个角色
44
-     */
45
-    public String[] hasAnyRoles() default {};
46
-}

+ 18 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/RequiresLogin.java

@@ -0,0 +1,18 @@
1
+package com.ruoyi.common.security.annotation;
2
+
3
+import java.lang.annotation.ElementType;
4
+import java.lang.annotation.Retention;
5
+import java.lang.annotation.RetentionPolicy;
6
+import java.lang.annotation.Target;
7
+
8
+/**
9
+ * 登录认证:只有登录之后才能进入该方法
10
+ * 
11
+ * @author ruoyi
12
+ *
13
+ */
14
+@Retention(RetentionPolicy.RUNTIME)
15
+@Target({ ElementType.METHOD, ElementType.TYPE })
16
+public @interface RequiresLogin
17
+{
18
+}

+ 27 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/RequiresPermissions.java

@@ -0,0 +1,27 @@
1
+package com.ruoyi.common.security.annotation;
2
+
3
+import java.lang.annotation.ElementType;
4
+import java.lang.annotation.Retention;
5
+import java.lang.annotation.RetentionPolicy;
6
+import java.lang.annotation.Target;
7
+
8
+/**
9
+ * 权限认证:必须具有指定权限才能进入该方法
10
+ * 
11
+ * @author ruoyi
12
+ *
13
+ */
14
+@Retention(RetentionPolicy.RUNTIME)
15
+@Target({ ElementType.METHOD, ElementType.TYPE })
16
+public @interface RequiresPermissions
17
+{
18
+    /**
19
+     * 需要校验的权限码
20
+     */
21
+    String[] value() default {};
22
+
23
+    /**
24
+     * 验证模式:AND | OR,默认AND
25
+     */
26
+    Logical logical() default Logical.AND;
27
+}

+ 26 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/annotation/RequiresRoles.java

@@ -0,0 +1,26 @@
1
+package com.ruoyi.common.security.annotation;
2
+
3
+import java.lang.annotation.ElementType;
4
+import java.lang.annotation.Retention;
5
+import java.lang.annotation.RetentionPolicy;
6
+import java.lang.annotation.Target;
7
+
8
+/**
9
+ * 角色认证:必须具有指定角色标识才能进入该方法
10
+ * 
11
+ * @author ruoyi
12
+ */
13
+@Retention(RetentionPolicy.RUNTIME)
14
+@Target({ ElementType.METHOD, ElementType.TYPE })
15
+public @interface RequiresRoles
16
+{
17
+    /**
18
+     * 需要校验的角色标识
19
+     */
20
+    String[] value() default {};
21
+
22
+    /**
23
+     * 验证逻辑:AND | OR,默认AND
24
+     */
25
+    Logical logical() default Logical.AND;
26
+}

+ 97 - 225
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/aspect/PreAuthorizeAspect.java

@@ -1,225 +1,97 @@
1
-package com.ruoyi.common.security.aspect;
2
-
3
-import java.lang.reflect.Method;
4
-import java.util.Collection;
5
-import org.aspectj.lang.ProceedingJoinPoint;
6
-import org.aspectj.lang.Signature;
7
-import org.aspectj.lang.annotation.Around;
8
-import org.aspectj.lang.annotation.Aspect;
9
-import org.aspectj.lang.reflect.MethodSignature;
10
-import org.springframework.beans.factory.annotation.Autowired;
11
-import org.springframework.stereotype.Component;
12
-import org.springframework.util.CollectionUtils;
13
-import org.springframework.util.PatternMatchUtils;
14
-import com.ruoyi.common.core.exception.PreAuthorizeException;
15
-import com.ruoyi.common.core.utils.StringUtils;
16
-import com.ruoyi.common.security.annotation.PreAuthorize;
17
-import com.ruoyi.common.security.service.TokenService;
18
-import com.ruoyi.system.api.model.LoginUser;
19
-
20
-/**
21
- * 自定义权限实现
22
- * 
23
- * @author ruoyi
24
- */
25
-@Aspect
26
-@Component
27
-public class PreAuthorizeAspect
28
-{
29
-    @Autowired
30
-    private TokenService tokenService;
31
-
32
-    /** 所有权限标识 */
33
-    private static final String ALL_PERMISSION = "*:*:*";
34
-
35
-    /** 管理员角色权限标识 */
36
-    private static final String SUPER_ADMIN = "admin";
37
-
38
-    /** 数组为0时 */
39
-    private static final Integer ARRAY_EMPTY = 0;
40
-
41
-    @Around("@annotation(com.ruoyi.common.security.annotation.PreAuthorize)")
42
-    public Object around(ProceedingJoinPoint point) throws Throwable
43
-    {
44
-        Signature signature = point.getSignature();
45
-        MethodSignature methodSignature = (MethodSignature) signature;
46
-        Method method = methodSignature.getMethod();
47
-        PreAuthorize annotation = method.getAnnotation(PreAuthorize.class);
48
-        if (annotation == null)
49
-        {
50
-            return point.proceed();
51
-        }
52
-
53
-        if (StringUtils.isNotEmpty(annotation.hasPermi()))
54
-        {
55
-            if (hasPermi(annotation.hasPermi()))
56
-            {
57
-                return point.proceed();
58
-            }
59
-            throw new PreAuthorizeException();
60
-        }
61
-        else if (StringUtils.isNotEmpty(annotation.lacksPermi()))
62
-        {
63
-            if (lacksPermi(annotation.lacksPermi()))
64
-            {
65
-                return point.proceed();
66
-            }
67
-            throw new PreAuthorizeException();
68
-        }
69
-        else if (ARRAY_EMPTY < annotation.hasAnyPermi().length)
70
-        {
71
-            if (hasAnyPermi(annotation.hasAnyPermi()))
72
-            {
73
-                return point.proceed();
74
-            }
75
-            throw new PreAuthorizeException();
76
-        }
77
-        else if (StringUtils.isNotEmpty(annotation.hasRole()))
78
-        {
79
-            if (hasRole(annotation.hasRole()))
80
-            {
81
-                return point.proceed();
82
-            }
83
-            throw new PreAuthorizeException();
84
-        }
85
-        else if (StringUtils.isNotEmpty(annotation.lacksRole()))
86
-        {
87
-            if (lacksRole(annotation.lacksRole()))
88
-            {
89
-                return point.proceed();
90
-            }
91
-            throw new PreAuthorizeException();
92
-        }
93
-        else if (ARRAY_EMPTY < annotation.hasAnyRoles().length)
94
-        {
95
-            if (hasAnyRoles(annotation.hasAnyRoles()))
96
-            {
97
-                return point.proceed();
98
-            }
99
-            throw new PreAuthorizeException();
100
-        }
101
-
102
-        return point.proceed();
103
-    }
104
-
105
-    /**
106
-     * 验证用户是否具备某权限
107
-     * 
108
-     * @param permission 权限字符串
109
-     * @return 用户是否具备某权限
110
-     */
111
-    public boolean hasPermi(String permission)
112
-    {
113
-        LoginUser userInfo = tokenService.getLoginUser();
114
-        if (StringUtils.isNull(userInfo) || CollectionUtils.isEmpty(userInfo.getPermissions()))
115
-        {
116
-            return false;
117
-        }
118
-        return hasPermissions(userInfo.getPermissions(), permission);
119
-    }
120
-
121
-    /**
122
-     * 验证用户是否不具备某权限,与 hasPermi逻辑相反
123
-     *
124
-     * @param permission 权限字符串
125
-     * @return 用户是否不具备某权限
126
-     */
127
-    public boolean lacksPermi(String permission)
128
-    {
129
-        return hasPermi(permission) != true;
130
-    }
131
-
132
-    /**
133
-     * 验证用户是否具有以下任意一个权限
134
-     *
135
-     * @param permissions 权限列表
136
-     * @return 用户是否具有以下任意一个权限
137
-     */
138
-    public boolean hasAnyPermi(String[] permissions)
139
-    {
140
-        LoginUser userInfo = tokenService.getLoginUser();
141
-        if (StringUtils.isNull(userInfo) || CollectionUtils.isEmpty(userInfo.getPermissions()))
142
-        {
143
-            return false;
144
-        }
145
-        Collection<String> authorities = userInfo.getPermissions();
146
-        for (String permission : permissions)
147
-        {
148
-            if (permission != null && hasPermissions(authorities, permission))
149
-            {
150
-                return true;
151
-            }
152
-        }
153
-        return false;
154
-    }
155
-
156
-    /**
157
-     * 判断用户是否拥有某个角色
158
-     * 
159
-     * @param role 角色字符串
160
-     * @return 用户是否具备某角色
161
-     */
162
-    public boolean hasRole(String role)
163
-    {
164
-        LoginUser userInfo = tokenService.getLoginUser();
165
-        if (StringUtils.isNull(userInfo) || CollectionUtils.isEmpty(userInfo.getRoles()))
166
-        {
167
-            return false;
168
-        }
169
-        for (String roleKey : userInfo.getRoles())
170
-        {
171
-            if (SUPER_ADMIN.equals(roleKey) || roleKey.equals(role))
172
-            {
173
-                return true;
174
-            }
175
-        }
176
-        return false;
177
-    }
178
-
179
-    /**
180
-     * 验证用户是否不具备某角色,与 isRole逻辑相反。
181
-     *
182
-     * @param role 角色名称
183
-     * @return 用户是否不具备某角色
184
-     */
185
-    public boolean lacksRole(String role)
186
-    {
187
-        return hasRole(role) != true;
188
-    }
189
-
190
-    /**
191
-     * 验证用户是否具有以下任意一个角色
192
-     *
193
-     * @param roles 角色列表
194
-     * @return 用户是否具有以下任意一个角色
195
-     */
196
-    public boolean hasAnyRoles(String[] roles)
197
-    {
198
-        LoginUser userInfo = tokenService.getLoginUser();
199
-        if (StringUtils.isNull(userInfo) || CollectionUtils.isEmpty(userInfo.getRoles()))
200
-        {
201
-            return false;
202
-        }
203
-        for (String role : roles)
204
-        {
205
-            if (hasRole(role))
206
-            {
207
-                return true;
208
-            }
209
-        }
210
-        return false;
211
-    }
212
-
213
-    /**
214
-     * 判断是否包含权限
215
-     * 
216
-     * @param authorities 权限列表
217
-     * @param permission 权限字符串
218
-     * @return 用户是否具备某权限
219
-     */
220
-    private boolean hasPermissions(Collection<String> authorities, String permission)
221
-    {
222
-        return authorities.stream().filter(StringUtils::hasText)
223
-                .anyMatch(x -> ALL_PERMISSION.contains(x) || PatternMatchUtils.simpleMatch(x, permission));
224
-    }
225
-}
1
+package com.ruoyi.common.security.aspect;
2
+
3
+import java.lang.reflect.Method;
4
+import org.aspectj.lang.ProceedingJoinPoint;
5
+import org.aspectj.lang.annotation.Around;
6
+import org.aspectj.lang.annotation.Aspect;
7
+import org.aspectj.lang.annotation.Pointcut;
8
+import org.aspectj.lang.reflect.MethodSignature;
9
+import org.springframework.stereotype.Component;
10
+import com.ruoyi.common.security.annotation.RequiresLogin;
11
+import com.ruoyi.common.security.annotation.RequiresPermissions;
12
+import com.ruoyi.common.security.annotation.RequiresRoles;
13
+import com.ruoyi.common.security.auth.AuthUtil;
14
+
15
+/**
16
+ * 基于 Spring Aop 的注解鉴权
17
+ * 
18
+ * @author kong
19
+ */
20
+@Aspect
21
+@Component
22
+public class PreAuthorizeAspect
23
+{
24
+    /**
25
+     * 构建
26
+     */
27
+    public PreAuthorizeAspect()
28
+    {
29
+    }
30
+
31
+    /**
32
+     * 定义AOP签名 (切入所有使用鉴权注解的方法)
33
+     */
34
+    public static final String POINTCUT_SIGN = " @annotation(com.ruoyi.common.security.annotation.RequiresLogin) || "
35
+            + "@annotation(com.ruoyi.common.security.annotation.RequiresPermissions) || "
36
+            + "@annotation(com.ruoyi.common.security.annotation.RequiresRoles)";
37
+
38
+    /**
39
+     * 声明AOP签名
40
+     */
41
+    @Pointcut(POINTCUT_SIGN)
42
+    public void pointcut()
43
+    {
44
+    }
45
+
46
+    /**
47
+     * 环绕切入
48
+     * 
49
+     * @param joinPoint 切面对象
50
+     * @return 底层方法执行后的返回值
51
+     * @throws Throwable 底层方法抛出的异常
52
+     */
53
+    @Around("pointcut()")
54
+    public Object around(ProceedingJoinPoint joinPoint) throws Throwable
55
+    {
56
+        // 注解鉴权
57
+        MethodSignature signature = (MethodSignature) joinPoint.getSignature();
58
+        checkMethodAnnotation(signature.getMethod());
59
+        try
60
+        {
61
+            // 执行原有逻辑
62
+            Object obj = joinPoint.proceed();
63
+            return obj;
64
+        }
65
+        catch (Throwable e)
66
+        {
67
+            throw e;
68
+        }
69
+    }
70
+
71
+    /**
72
+     * 对一个Method对象进行注解检查
73
+     */
74
+    public void checkMethodAnnotation(Method method)
75
+    {
76
+        // 校验 @RequiresLogin 注解
77
+        RequiresLogin requiresLogin = method.getAnnotation(RequiresLogin.class);
78
+        if (requiresLogin != null)
79
+        {
80
+            AuthUtil.checkLogin();
81
+        }
82
+
83
+        // 校验 @RequiresRoles 注解
84
+        RequiresRoles requiresRoles = method.getAnnotation(RequiresRoles.class);
85
+        if (requiresRoles != null)
86
+        {
87
+            AuthUtil.checkRole(requiresRoles);
88
+        }
89
+
90
+        // 校验 @RequiresPermissions 注解
91
+        RequiresPermissions requiresPermissions = method.getAnnotation(RequiresPermissions.class);
92
+        if (requiresPermissions != null)
93
+        {
94
+            AuthUtil.checkPermi(requiresPermissions);
95
+        }
96
+    }
97
+}

+ 329 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/auth/AuthLogic.java

@@ -0,0 +1,329 @@
1
+package com.ruoyi.common.security.auth;
2
+
3
+import java.util.Collection;
4
+import java.util.HashSet;
5
+import java.util.Set;
6
+import org.springframework.util.PatternMatchUtils;
7
+import com.ruoyi.common.core.exception.auth.NotLoginException;
8
+import com.ruoyi.common.core.exception.auth.NotPermissionException;
9
+import com.ruoyi.common.core.exception.auth.NotRoleException;
10
+import com.ruoyi.common.core.utils.SecurityUtils;
11
+import com.ruoyi.common.core.utils.SpringUtils;
12
+import com.ruoyi.common.core.utils.StringUtils;
13
+import com.ruoyi.common.security.annotation.Logical;
14
+import com.ruoyi.common.security.annotation.RequiresLogin;
15
+import com.ruoyi.common.security.annotation.RequiresPermissions;
16
+import com.ruoyi.common.security.annotation.RequiresRoles;
17
+import com.ruoyi.common.security.service.TokenService;
18
+import com.ruoyi.system.api.model.LoginUser;
19
+
20
+/**
21
+ * Token 权限验证,逻辑实现类
22
+ * 
23
+ * @author ruoyi
24
+ */
25
+public class AuthLogic
26
+{
27
+    /** 所有权限标识 */
28
+    private static final String ALL_PERMISSION = "*:*:*";
29
+
30
+    /** 管理员角色权限标识 */
31
+    private static final String SUPER_ADMIN = "admin";
32
+
33
+    public TokenService tokenService = SpringUtils.getBean(TokenService.class);
34
+
35
+    /**
36
+     * 检验用户是否已经登录,如未登录,则抛出异常
37
+     */
38
+    public void checkLogin()
39
+    {
40
+        getLoginUser();
41
+    }
42
+
43
+    /**
44
+     * 获取当前用户缓存信息, 如果未登录,则抛出异常
45
+     * 
46
+     * @return 用户缓存信息
47
+     */
48
+    public LoginUser getLoginUser()
49
+    {
50
+        String token = SecurityUtils.getToken();
51
+        if (token == null)
52
+        {
53
+            throw new NotLoginException("未提供token");
54
+        }
55
+        LoginUser loginUser = tokenService.getLoginUser(token);
56
+        if (loginUser == null)
57
+        {
58
+            throw new NotLoginException("无效的token");
59
+        }
60
+        return loginUser;
61
+    }
62
+
63
+    /**
64
+     * 验证用户是否具备某权限
65
+     * 
66
+     * @param permission 权限字符串
67
+     * @return 用户是否具备某权限
68
+     */
69
+    public boolean hasPermi(String permission)
70
+    {
71
+        return hasPermi(getPermiList(), permission);
72
+    }
73
+
74
+    /**
75
+     * 验证用户是否具备某权限, 如果验证未通过,则抛出异常: NotPermissionException
76
+     * 
77
+     * @param permission 权限字符串
78
+     * @return 用户是否具备某权限
79
+     */
80
+    public void checkPermi(String permission)
81
+    {
82
+        if (!hasPermi(getPermiList(), permission))
83
+        {
84
+            throw new NotPermissionException(permission);
85
+        }
86
+    }
87
+
88
+    /**
89
+     * 根据注解(@RequiresPermissions)鉴权, 如果验证未通过,则抛出异常: NotPermissionException
90
+     * 
91
+     * @param requiresPermissions 注解对象
92
+     */
93
+    public void checkPermi(RequiresPermissions requiresPermissions)
94
+    {
95
+        if (requiresPermissions.logical() == Logical.AND)
96
+        {
97
+            checkPermiAnd(requiresPermissions.value());
98
+        }
99
+        else
100
+        {
101
+            checkPermiOr(requiresPermissions.value());
102
+        }
103
+    }
104
+
105
+    /**
106
+     * 验证用户是否含有指定权限,必须全部拥有
107
+     *
108
+     * @param permissions 权限列表
109
+     */
110
+    public void checkPermiAnd(String... permissions)
111
+    {
112
+        Set<String> permissionList = getPermiList();
113
+        for (String permission : permissions)
114
+        {
115
+            if (!hasPermi(permissionList, permission))
116
+            {
117
+                throw new NotPermissionException(permission);
118
+            }
119
+        }
120
+    }
121
+
122
+    /**
123
+     * 验证用户是否含有指定权限,只需包含其中一个
124
+     * 
125
+     * @param permissions 权限码数组
126
+     */
127
+    public void checkPermiOr(String... permissions)
128
+    {
129
+        Set<String> permissionList = getPermiList();
130
+        for (String permission : permissions)
131
+        {
132
+            if (hasPermi(permissionList, permission))
133
+            {
134
+                return;
135
+            }
136
+        }
137
+        if (permissions.length > 0)
138
+        {
139
+            throw new NotPermissionException(permissions);
140
+        }
141
+    }
142
+
143
+    /**
144
+     * 判断用户是否拥有某个角色
145
+     * 
146
+     * @param role 角色标识
147
+     * @return 用户是否具备某角色
148
+     */
149
+    public boolean hasRole(String role)
150
+    {
151
+        return hasRole(getRoleList(), role);
152
+    }
153
+
154
+    /**
155
+     * 判断用户是否拥有某个角色, 如果验证未通过,则抛出异常: NotRoleException
156
+     * 
157
+     * @param role 角色标识
158
+     */
159
+    public void checkRole(String role)
160
+    {
161
+        if (!hasRole(role))
162
+        {
163
+            throw new NotRoleException(role);
164
+        }
165
+    }
166
+
167
+    /**
168
+     * 根据注解(@RequiresRoles)鉴权
169
+     * 
170
+     * @param requiresRoles 注解对象
171
+     */
172
+    public void checkRole(RequiresRoles requiresRoles)
173
+    {
174
+        if (requiresRoles.logical() == Logical.AND)
175
+        {
176
+            checkRoleAnd(requiresRoles.value());
177
+        }
178
+        else
179
+        {
180
+            checkRoleOr(requiresRoles.value());
181
+        }
182
+    }
183
+
184
+    /**
185
+     * 验证用户是否含有指定角色,必须全部拥有
186
+     * 
187
+     * @param roles 角色标识数组
188
+     */
189
+    public void checkRoleAnd(String... roles)
190
+    {
191
+        Set<String> roleList = getRoleList();
192
+        for (String role : roles)
193
+        {
194
+            if (!hasRole(roleList, role))
195
+            {
196
+                throw new NotRoleException(role);
197
+            }
198
+        }
199
+    }
200
+
201
+    /**
202
+     * 验证用户是否含有指定角色,只需包含其中一个
203
+     * 
204
+     * @param roles 角色标识数组
205
+     */
206
+    public void checkRoleOr(String... roles)
207
+    {
208
+        Set<String> roleList = getRoleList();
209
+        for (String role : roles)
210
+        {
211
+            if (hasRole(roleList, role))
212
+            {
213
+                return;
214
+            }
215
+        }
216
+        if (roles.length > 0)
217
+        {
218
+            throw new NotRoleException(roles);
219
+        }
220
+    }
221
+
222
+    /**
223
+     * 根据注解(@RequiresLogin)鉴权
224
+     * 
225
+     * @param at 注解对象
226
+     */
227
+    public void checkByAnnotation(RequiresLogin at)
228
+    {
229
+        this.checkLogin();
230
+    }
231
+
232
+    /**
233
+     * 根据注解(@RequiresRoles)鉴权
234
+     * 
235
+     * @param at 注解对象
236
+     */
237
+    public void checkByAnnotation(RequiresRoles at)
238
+    {
239
+        String[] roleArray = at.value();
240
+        if (at.logical() == Logical.AND)
241
+        {
242
+            this.checkRoleAnd(roleArray);
243
+        }
244
+        else
245
+        {
246
+            this.checkRoleOr(roleArray);
247
+        }
248
+    }
249
+
250
+    /**
251
+     * 根据注解(@RequiresPermissions)鉴权
252
+     * 
253
+     * @param at 注解对象
254
+     */
255
+    public void checkByAnnotation(RequiresPermissions at)
256
+    {
257
+        String[] permissionArray = at.value();
258
+        if (at.logical() == Logical.AND)
259
+        {
260
+            this.checkPermiAnd(permissionArray);
261
+        }
262
+        else
263
+        {
264
+            this.checkPermiOr(permissionArray);
265
+        }
266
+    }
267
+
268
+    /**
269
+     * 获取当前账号的角色列表
270
+     * 
271
+     * @return 角色列表
272
+     */
273
+    public Set<String> getRoleList()
274
+    {
275
+        try
276
+        {
277
+            LoginUser loginUser = getLoginUser();
278
+            return loginUser.getRoles();
279
+        }
280
+        catch (Exception e)
281
+        {
282
+            return new HashSet<>();
283
+        }
284
+    }
285
+
286
+    /**
287
+     * 获取当前账号的权限列表
288
+     * 
289
+     * @return 权限列表
290
+     */
291
+    public Set<String> getPermiList()
292
+    {
293
+        try
294
+        {
295
+            LoginUser loginUser = getLoginUser();
296
+            return loginUser.getPermissions();
297
+        }
298
+        catch (Exception e)
299
+        {
300
+            return new HashSet<>();
301
+        }
302
+    }
303
+
304
+    /**
305
+     * 判断是否包含权限
306
+     * 
307
+     * @param authorities 权限列表
308
+     * @param permission 权限字符串
309
+     * @return 用户是否具备某权限
310
+     */
311
+    public boolean hasPermi(Collection<String> authorities, String permission)
312
+    {
313
+        return authorities.stream().filter(StringUtils::hasText)
314
+                .anyMatch(x -> ALL_PERMISSION.contains(x) || PatternMatchUtils.simpleMatch(x, permission));
315
+    }
316
+
317
+    /**
318
+     * 判断是否包含角色
319
+     * 
320
+     * @param roles 角色列表
321
+     * @param role 角色
322
+     * @return 用户是否具备某角色权限
323
+     */
324
+    public boolean hasRole(Collection<String> roles, String role)
325
+    {
326
+        return roles.stream().filter(StringUtils::hasText)
327
+                .anyMatch(x -> SUPER_ADMIN.contains(x) || PatternMatchUtils.simpleMatch(x, role));
328
+    }
329
+}

+ 127 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/auth/AuthUtil.java

@@ -0,0 +1,127 @@
1
+package com.ruoyi.common.security.auth;
2
+
3
+import com.ruoyi.common.security.annotation.RequiresPermissions;
4
+import com.ruoyi.common.security.annotation.RequiresRoles;
5
+
6
+/**
7
+ * Token 权限验证工具类
8
+ * 
9
+ * @author ruoyi
10
+ */
11
+public class AuthUtil
12
+{
13
+    /**
14
+     * 底层的 AuthLogic 对象
15
+     */
16
+    public static AuthLogic authLogic = new AuthLogic();
17
+
18
+    /**
19
+     * 检验当前会话是否已经登录,如未登录,则抛出异常
20
+     */
21
+    public static void checkLogin()
22
+    {
23
+        authLogic.checkLogin();
24
+    }
25
+
26
+    /**
27
+     * 当前账号是否含有指定角色标识, 返回true或false
28
+     * 
29
+     * @param role 角色标识
30
+     * @return 是否含有指定角色标识
31
+     */
32
+    public static boolean hasRole(String role)
33
+    {
34
+        return authLogic.hasRole(role);
35
+    }
36
+
37
+    /**
38
+     * 当前账号是否含有指定角色标识, 如果验证未通过,则抛出异常: NotRoleException
39
+     * 
40
+     * @param role 角色标识
41
+     */
42
+    public static void checkRole(String role)
43
+    {
44
+        authLogic.checkRole(role);
45
+    }
46
+
47
+    /**
48
+     * 根据注解传入参数鉴权, 如果验证未通过,则抛出异常: NotRoleException
49
+     * 
50
+     * @param requiresRoles 角色权限注解
51
+     */
52
+    public static void checkRole(RequiresRoles requiresRoles)
53
+    {
54
+        authLogic.checkRole(requiresRoles);
55
+    }
56
+
57
+    /**
58
+     * 当前账号是否含有指定角色标识 [指定多个,必须全部验证通过]
59
+     * 
60
+     * @param roles 角色标识数组
61
+     */
62
+    public static void checkRoleAnd(String... roles)
63
+    {
64
+        authLogic.checkRoleAnd(roles);
65
+    }
66
+
67
+    /**
68
+     * 当前账号是否含有指定角色标识 [指定多个,只要其一验证通过即可]
69
+     * 
70
+     * @param roles 角色标识数组
71
+     */
72
+    public static void checkRoleOr(String... roles)
73
+    {
74
+        authLogic.checkRoleOr(roles);
75
+    }
76
+
77
+    /**
78
+     * 当前账号是否含有指定权限, 返回true或false
79
+     * 
80
+     * @param permission 权限码
81
+     * @return 是否含有指定权限
82
+     */
83
+    public static boolean hasPermi(String permission)
84
+    {
85
+        return authLogic.hasPermi(permission);
86
+    }
87
+
88
+    /**
89
+     * 当前账号是否含有指定权限, 如果验证未通过,则抛出异常: NotPermissionException
90
+     * 
91
+     * @param permission 权限码
92
+     */
93
+    public static void checkPermi(String permission)
94
+    {
95
+        authLogic.checkPermi(permission);
96
+    }
97
+
98
+    /**
99
+     * 根据注解传入参数鉴权, 如果验证未通过,则抛出异常: NotPermissionException
100
+     * 
101
+     * @param requiresPermissions 权限注解
102
+     */
103
+    public static void checkPermi(RequiresPermissions requiresPermissions)
104
+    {
105
+        authLogic.checkPermi(requiresPermissions);
106
+    }
107
+
108
+    /**
109
+     * 当前账号是否含有指定权限 [指定多个,必须全部验证通过]
110
+     * 
111
+     * @param permissions 权限码数组
112
+     */
113
+    public static void checkPermiAnd(String... permissions)
114
+    {
115
+        authLogic.checkPermiAnd(permissions);
116
+    }
117
+
118
+    /**
119
+     * 当前账号是否含有指定权限 [指定多个,只要其一验证通过即可]
120
+     * 
121
+     * @param permissions 权限码数组
122
+     */
123
+    public static void checkPermiOr(String... permissions)
124
+    {
125
+        authLogic.checkPermiOr(permissions);
126
+    }
127
+}

+ 18 - 6
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/handler/GlobalExceptionHandler.java

@@ -11,8 +11,9 @@ import org.springframework.web.bind.annotation.RestControllerAdvice;
11
 import com.ruoyi.common.core.constant.HttpStatus;
11
 import com.ruoyi.common.core.constant.HttpStatus;
12
 import com.ruoyi.common.core.exception.DemoModeException;
12
 import com.ruoyi.common.core.exception.DemoModeException;
13
 import com.ruoyi.common.core.exception.InnerAuthException;
13
 import com.ruoyi.common.core.exception.InnerAuthException;
14
-import com.ruoyi.common.core.exception.PreAuthorizeException;
15
 import com.ruoyi.common.core.exception.ServiceException;
14
 import com.ruoyi.common.core.exception.ServiceException;
15
+import com.ruoyi.common.core.exception.auth.NotPermissionException;
16
+import com.ruoyi.common.core.exception.auth.NotRoleException;
16
 import com.ruoyi.common.core.utils.StringUtils;
17
 import com.ruoyi.common.core.utils.StringUtils;
17
 import com.ruoyi.common.core.web.domain.AjaxResult;
18
 import com.ruoyi.common.core.web.domain.AjaxResult;
18
 
19
 
@@ -27,14 +28,25 @@ public class GlobalExceptionHandler
27
     private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);
28
     private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);
28
 
29
 
29
     /**
30
     /**
30
-     * 权限异常
31
+     * 权限异常
31
      */
32
      */
32
-    @ExceptionHandler(PreAuthorizeException.class)
33
-    public AjaxResult handlePreAuthorizeException(PreAuthorizeException e, HttpServletRequest request)
33
+    @ExceptionHandler(NotPermissionException.class)
34
+    public AjaxResult handleNotPermissionException(NotPermissionException e, HttpServletRequest request)
34
     {
35
     {
35
         String requestURI = request.getRequestURI();
36
         String requestURI = request.getRequestURI();
36
-        log.error("请求地址'{}',权限校验失败'{}'", requestURI, e.getMessage());
37
-        return AjaxResult.error(HttpStatus.FORBIDDEN, "没有权限,请联系管理员授权");
37
+        log.error("请求地址'{}',权限码校验失败'{}'", requestURI, e.getMessage());
38
+        return AjaxResult.error(HttpStatus.FORBIDDEN, "没有访问权限,请联系管理员授权");
39
+    }
40
+
41
+    /**
42
+     * 角色权限异常
43
+     */
44
+    @ExceptionHandler(NotRoleException.class)
45
+    public AjaxResult handleNotRoleException(NotRoleException e, HttpServletRequest request)
46
+    {
47
+        String requestURI = request.getRequestURI();
48
+        log.error("请求地址'{}',角色权限校验失败'{}'", requestURI, e.getMessage());
49
+        return AjaxResult.error(HttpStatus.FORBIDDEN, "没有访问权限,请联系管理员授权");
38
     }
50
     }
39
 
51
 
40
     /**
52
     /**

+ 12 - 12
ruoyi-modules/ruoyi-gen/src/main/java/com/ruoyi/gen/controller/GenController.java

@@ -22,7 +22,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
22
 import com.ruoyi.common.core.web.page.TableDataInfo;
22
 import com.ruoyi.common.core.web.page.TableDataInfo;
23
 import com.ruoyi.common.log.annotation.Log;
23
 import com.ruoyi.common.log.annotation.Log;
24
 import com.ruoyi.common.log.enums.BusinessType;
24
 import com.ruoyi.common.log.enums.BusinessType;
25
-import com.ruoyi.common.security.annotation.PreAuthorize;
25
+import com.ruoyi.common.security.annotation.RequiresPermissions;
26
 import com.ruoyi.gen.domain.GenTable;
26
 import com.ruoyi.gen.domain.GenTable;
27
 import com.ruoyi.gen.domain.GenTableColumn;
27
 import com.ruoyi.gen.domain.GenTableColumn;
28
 import com.ruoyi.gen.service.IGenTableColumnService;
28
 import com.ruoyi.gen.service.IGenTableColumnService;
@@ -46,7 +46,7 @@ public class GenController extends BaseController
46
     /**
46
     /**
47
      * 查询代码生成列表
47
      * 查询代码生成列表
48
      */
48
      */
49
-    @PreAuthorize(hasPermi = "tool:gen:list")
49
+    @RequiresPermissions("tool:gen:list")
50
     @GetMapping("/list")
50
     @GetMapping("/list")
51
     public TableDataInfo genList(GenTable genTable)
51
     public TableDataInfo genList(GenTable genTable)
52
     {
52
     {
@@ -58,7 +58,7 @@ public class GenController extends BaseController
58
     /**
58
     /**
59
      * 修改代码生成业务
59
      * 修改代码生成业务
60
      */
60
      */
61
-    @PreAuthorize(hasPermi = "tool:gen:query")
61
+    @RequiresPermissions("tool:gen:query")
62
     @GetMapping(value = "/{talbleId}")
62
     @GetMapping(value = "/{talbleId}")
63
     public AjaxResult getInfo(@PathVariable Long talbleId)
63
     public AjaxResult getInfo(@PathVariable Long talbleId)
64
     {
64
     {
@@ -75,7 +75,7 @@ public class GenController extends BaseController
75
     /**
75
     /**
76
      * 查询数据库列表
76
      * 查询数据库列表
77
      */
77
      */
78
-    @PreAuthorize(hasPermi = "tool:gen:list")
78
+    @RequiresPermissions("tool:gen:list")
79
     @GetMapping("/db/list")
79
     @GetMapping("/db/list")
80
     public TableDataInfo dataList(GenTable genTable)
80
     public TableDataInfo dataList(GenTable genTable)
81
     {
81
     {
@@ -100,7 +100,7 @@ public class GenController extends BaseController
100
     /**
100
     /**
101
      * 导入表结构(保存)
101
      * 导入表结构(保存)
102
      */
102
      */
103
-    @PreAuthorize(hasPermi = "tool:gen:import")
103
+    @RequiresPermissions("tool:gen:import")
104
     @Log(title = "代码生成", businessType = BusinessType.IMPORT)
104
     @Log(title = "代码生成", businessType = BusinessType.IMPORT)
105
     @PostMapping("/importTable")
105
     @PostMapping("/importTable")
106
     public AjaxResult importTableSave(String tables)
106
     public AjaxResult importTableSave(String tables)
@@ -115,7 +115,7 @@ public class GenController extends BaseController
115
     /**
115
     /**
116
      * 修改保存代码生成业务
116
      * 修改保存代码生成业务
117
      */
117
      */
118
-    @PreAuthorize(hasPermi = "tool:gen:edit")
118
+    @RequiresPermissions("tool:gen:edit")
119
     @Log(title = "代码生成", businessType = BusinessType.UPDATE)
119
     @Log(title = "代码生成", businessType = BusinessType.UPDATE)
120
     @PutMapping
120
     @PutMapping
121
     public AjaxResult editSave(@Validated @RequestBody GenTable genTable)
121
     public AjaxResult editSave(@Validated @RequestBody GenTable genTable)
@@ -128,7 +128,7 @@ public class GenController extends BaseController
128
     /**
128
     /**
129
      * 删除代码生成
129
      * 删除代码生成
130
      */
130
      */
131
-    @PreAuthorize(hasPermi = "tool:gen:remove")
131
+    @RequiresPermissions("tool:gen:remove")
132
     @Log(title = "代码生成", businessType = BusinessType.DELETE)
132
     @Log(title = "代码生成", businessType = BusinessType.DELETE)
133
     @DeleteMapping("/{tableIds}")
133
     @DeleteMapping("/{tableIds}")
134
     public AjaxResult remove(@PathVariable Long[] tableIds)
134
     public AjaxResult remove(@PathVariable Long[] tableIds)
@@ -140,7 +140,7 @@ public class GenController extends BaseController
140
     /**
140
     /**
141
      * 预览代码
141
      * 预览代码
142
      */
142
      */
143
-    @PreAuthorize(hasPermi = "tool:gen:preview")
143
+    @RequiresPermissions("tool:gen:preview")
144
     @GetMapping("/preview/{tableId}")
144
     @GetMapping("/preview/{tableId}")
145
     public AjaxResult preview(@PathVariable("tableId") Long tableId) throws IOException
145
     public AjaxResult preview(@PathVariable("tableId") Long tableId) throws IOException
146
     {
146
     {
@@ -151,7 +151,7 @@ public class GenController extends BaseController
151
     /**
151
     /**
152
      * 生成代码(下载方式)
152
      * 生成代码(下载方式)
153
      */
153
      */
154
-    @PreAuthorize(hasPermi = "tool:gen:code")
154
+    @RequiresPermissions("tool:gen:code")
155
     @Log(title = "代码生成", businessType = BusinessType.GENCODE)
155
     @Log(title = "代码生成", businessType = BusinessType.GENCODE)
156
     @GetMapping("/download/{tableName}")
156
     @GetMapping("/download/{tableName}")
157
     public void download(HttpServletResponse response, @PathVariable("tableName") String tableName) throws IOException
157
     public void download(HttpServletResponse response, @PathVariable("tableName") String tableName) throws IOException
@@ -163,7 +163,7 @@ public class GenController extends BaseController
163
     /**
163
     /**
164
      * 生成代码(自定义路径)
164
      * 生成代码(自定义路径)
165
      */
165
      */
166
-    @PreAuthorize(hasPermi = "tool:gen:code")
166
+    @RequiresPermissions("tool:gen:code")
167
     @Log(title = "代码生成", businessType = BusinessType.GENCODE)
167
     @Log(title = "代码生成", businessType = BusinessType.GENCODE)
168
     @GetMapping("/genCode/{tableName}")
168
     @GetMapping("/genCode/{tableName}")
169
     public AjaxResult genCode(@PathVariable("tableName") String tableName)
169
     public AjaxResult genCode(@PathVariable("tableName") String tableName)
@@ -175,7 +175,7 @@ public class GenController extends BaseController
175
     /**
175
     /**
176
      * 同步数据库
176
      * 同步数据库
177
      */
177
      */
178
-    @PreAuthorize(hasPermi = "tool:gen:edit")
178
+    @RequiresPermissions("tool:gen:edit")
179
     @Log(title = "代码生成", businessType = BusinessType.UPDATE)
179
     @Log(title = "代码生成", businessType = BusinessType.UPDATE)
180
     @GetMapping("/synchDb/{tableName}")
180
     @GetMapping("/synchDb/{tableName}")
181
     public AjaxResult synchDb(@PathVariable("tableName") String tableName)
181
     public AjaxResult synchDb(@PathVariable("tableName") String tableName)
@@ -187,7 +187,7 @@ public class GenController extends BaseController
187
     /**
187
     /**
188
      * 批量生成代码
188
      * 批量生成代码
189
      */
189
      */
190
-    @PreAuthorize(hasPermi = "tool:gen:code")
190
+    @RequiresPermissions("tool:gen:code")
191
     @Log(title = "代码生成", businessType = BusinessType.GENCODE)
191
     @Log(title = "代码生成", businessType = BusinessType.GENCODE)
192
     @GetMapping("/batchGenCode")
192
     @GetMapping("/batchGenCode")
193
     public void batchGenCode(HttpServletResponse response, String tables) throws IOException
193
     public void batchGenCode(HttpServletResponse response, String tables) throws IOException

+ 7 - 7
ruoyi-modules/ruoyi-gen/src/main/resources/vm/java/controller.java.vm

@@ -14,7 +14,7 @@ import org.springframework.web.bind.annotation.RequestMapping;
14
 import org.springframework.web.bind.annotation.RestController;
14
 import org.springframework.web.bind.annotation.RestController;
15
 import com.ruoyi.common.log.annotation.Log;
15
 import com.ruoyi.common.log.annotation.Log;
16
 import com.ruoyi.common.log.enums.BusinessType;
16
 import com.ruoyi.common.log.enums.BusinessType;
17
-import com.ruoyi.common.security.annotation.PreAuthorize;
17
+import com.ruoyi.common.security.annotation.RequiresPermissions;
18
 import ${packageName}.domain.${ClassName};
18
 import ${packageName}.domain.${ClassName};
19
 import ${packageName}.service.I${ClassName}Service;
19
 import ${packageName}.service.I${ClassName}Service;
20
 import com.ruoyi.common.core.web.controller.BaseController;
20
 import com.ruoyi.common.core.web.controller.BaseController;
@@ -41,7 +41,7 @@ public class ${ClassName}Controller extends BaseController
41
     /**
41
     /**
42
      * 查询${functionName}列表
42
      * 查询${functionName}列表
43
      */
43
      */
44
-    @PreAuthorize(hasPermi = "${permissionPrefix}:list")
44
+    @RequiresPermissions("${permissionPrefix}:list")
45
     @GetMapping("/list")
45
     @GetMapping("/list")
46
 #if($table.crud || $table.sub)
46
 #if($table.crud || $table.sub)
47
     public TableDataInfo list(${ClassName} ${className})
47
     public TableDataInfo list(${ClassName} ${className})
@@ -61,7 +61,7 @@ public class ${ClassName}Controller extends BaseController
61
     /**
61
     /**
62
      * 导出${functionName}列表
62
      * 导出${functionName}列表
63
      */
63
      */
64
-    @PreAuthorize(hasPermi = "${permissionPrefix}:export")
64
+    @RequiresPermissions("${permissionPrefix}:export")
65
     @Log(title = "${functionName}", businessType = BusinessType.EXPORT)
65
     @Log(title = "${functionName}", businessType = BusinessType.EXPORT)
66
     @PostMapping("/export")
66
     @PostMapping("/export")
67
     public void export(HttpServletResponse response, ${ClassName} ${className}) throws IOException
67
     public void export(HttpServletResponse response, ${ClassName} ${className}) throws IOException
@@ -74,7 +74,7 @@ public class ${ClassName}Controller extends BaseController
74
     /**
74
     /**
75
      * 获取${functionName}详细信息
75
      * 获取${functionName}详细信息
76
      */
76
      */
77
-    @PreAuthorize(hasPermi = "${permissionPrefix}:query")
77
+    @RequiresPermissions("${permissionPrefix}:query")
78
     @GetMapping(value = "/{${pkColumn.javaField}}")
78
     @GetMapping(value = "/{${pkColumn.javaField}}")
79
     public AjaxResult getInfo(@PathVariable("${pkColumn.javaField}") ${pkColumn.javaType} ${pkColumn.javaField})
79
     public AjaxResult getInfo(@PathVariable("${pkColumn.javaField}") ${pkColumn.javaType} ${pkColumn.javaField})
80
     {
80
     {
@@ -84,7 +84,7 @@ public class ${ClassName}Controller extends BaseController
84
     /**
84
     /**
85
      * 新增${functionName}
85
      * 新增${functionName}
86
      */
86
      */
87
-    @PreAuthorize(hasPermi = "${permissionPrefix}:add")
87
+    @RequiresPermissions("${permissionPrefix}:add")
88
     @Log(title = "${functionName}", businessType = BusinessType.INSERT)
88
     @Log(title = "${functionName}", businessType = BusinessType.INSERT)
89
     @PostMapping
89
     @PostMapping
90
     public AjaxResult add(@RequestBody ${ClassName} ${className})
90
     public AjaxResult add(@RequestBody ${ClassName} ${className})
@@ -95,7 +95,7 @@ public class ${ClassName}Controller extends BaseController
95
     /**
95
     /**
96
      * 修改${functionName}
96
      * 修改${functionName}
97
      */
97
      */
98
-    @PreAuthorize(hasPermi = "${permissionPrefix}:edit")
98
+    @RequiresPermissions("${permissionPrefix}:edit")
99
     @Log(title = "${functionName}", businessType = BusinessType.UPDATE)
99
     @Log(title = "${functionName}", businessType = BusinessType.UPDATE)
100
     @PutMapping
100
     @PutMapping
101
     public AjaxResult edit(@RequestBody ${ClassName} ${className})
101
     public AjaxResult edit(@RequestBody ${ClassName} ${className})
@@ -106,7 +106,7 @@ public class ${ClassName}Controller extends BaseController
106
     /**
106
     /**
107
      * 删除${functionName}
107
      * 删除${functionName}
108
      */
108
      */
109
-    @PreAuthorize(hasPermi = "${permissionPrefix}:remove")
109
+    @RequiresPermissions("${permissionPrefix}:remove")
110
     @Log(title = "${functionName}", businessType = BusinessType.DELETE)
110
     @Log(title = "${functionName}", businessType = BusinessType.DELETE)
111
 	@DeleteMapping("/{${pkColumn.javaField}s}")
111
 	@DeleteMapping("/{${pkColumn.javaField}s}")
112
     public AjaxResult remove(@PathVariable ${pkColumn.javaType}[] ${pkColumn.javaField}s)
112
     public AjaxResult remove(@PathVariable ${pkColumn.javaType}[] ${pkColumn.javaField}s)

+ 9 - 9
ruoyi-modules/ruoyi-job/src/main/java/com/ruoyi/job/controller/SysJobController.java

@@ -23,7 +23,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
23
 import com.ruoyi.common.core.web.page.TableDataInfo;
23
 import com.ruoyi.common.core.web.page.TableDataInfo;
24
 import com.ruoyi.common.log.annotation.Log;
24
 import com.ruoyi.common.log.annotation.Log;
25
 import com.ruoyi.common.log.enums.BusinessType;
25
 import com.ruoyi.common.log.enums.BusinessType;
26
-import com.ruoyi.common.security.annotation.PreAuthorize;
26
+import com.ruoyi.common.security.annotation.RequiresPermissions;
27
 import com.ruoyi.job.domain.SysJob;
27
 import com.ruoyi.job.domain.SysJob;
28
 import com.ruoyi.job.service.ISysJobService;
28
 import com.ruoyi.job.service.ISysJobService;
29
 import com.ruoyi.job.util.CronUtils;
29
 import com.ruoyi.job.util.CronUtils;
@@ -43,7 +43,7 @@ public class SysJobController extends BaseController
43
     /**
43
     /**
44
      * 查询定时任务列表
44
      * 查询定时任务列表
45
      */
45
      */
46
-    @PreAuthorize(hasPermi = "monitor:job:list")
46
+    @RequiresPermissions("monitor:job:list")
47
     @GetMapping("/list")
47
     @GetMapping("/list")
48
     public TableDataInfo list(SysJob sysJob)
48
     public TableDataInfo list(SysJob sysJob)
49
     {
49
     {
@@ -55,7 +55,7 @@ public class SysJobController extends BaseController
55
     /**
55
     /**
56
      * 导出定时任务列表
56
      * 导出定时任务列表
57
      */
57
      */
58
-    @PreAuthorize(hasPermi = "monitor:job:export")
58
+    @RequiresPermissions("monitor:job:export")
59
     @Log(title = "定时任务", businessType = BusinessType.EXPORT)
59
     @Log(title = "定时任务", businessType = BusinessType.EXPORT)
60
     @PostMapping("/export")
60
     @PostMapping("/export")
61
     public void export(HttpServletResponse response, SysJob sysJob) throws IOException
61
     public void export(HttpServletResponse response, SysJob sysJob) throws IOException
@@ -68,7 +68,7 @@ public class SysJobController extends BaseController
68
     /**
68
     /**
69
      * 获取定时任务详细信息
69
      * 获取定时任务详细信息
70
      */
70
      */
71
-    @PreAuthorize(hasPermi = "monitor:job:query")
71
+    @RequiresPermissions("monitor:job:query")
72
     @GetMapping(value = "/{jobId}")
72
     @GetMapping(value = "/{jobId}")
73
     public AjaxResult getInfo(@PathVariable("jobId") Long jobId)
73
     public AjaxResult getInfo(@PathVariable("jobId") Long jobId)
74
     {
74
     {
@@ -78,7 +78,7 @@ public class SysJobController extends BaseController
78
     /**
78
     /**
79
      * 新增定时任务
79
      * 新增定时任务
80
      */
80
      */
81
-    @PreAuthorize(hasPermi = "monitor:job:add")
81
+    @RequiresPermissions("monitor:job:add")
82
     @Log(title = "定时任务", businessType = BusinessType.INSERT)
82
     @Log(title = "定时任务", businessType = BusinessType.INSERT)
83
     @PostMapping
83
     @PostMapping
84
     public AjaxResult add(@RequestBody SysJob job) throws SchedulerException, TaskException
84
     public AjaxResult add(@RequestBody SysJob job) throws SchedulerException, TaskException
@@ -106,7 +106,7 @@ public class SysJobController extends BaseController
106
     /**
106
     /**
107
      * 修改定时任务
107
      * 修改定时任务
108
      */
108
      */
109
-    @PreAuthorize(hasPermi = "monitor:job:edit")
109
+    @RequiresPermissions("monitor:job:edit")
110
     @Log(title = "定时任务", businessType = BusinessType.UPDATE)
110
     @Log(title = "定时任务", businessType = BusinessType.UPDATE)
111
     @PutMapping
111
     @PutMapping
112
     public AjaxResult edit(@RequestBody SysJob job) throws SchedulerException, TaskException
112
     public AjaxResult edit(@RequestBody SysJob job) throws SchedulerException, TaskException
@@ -134,7 +134,7 @@ public class SysJobController extends BaseController
134
     /**
134
     /**
135
      * 定时任务状态修改
135
      * 定时任务状态修改
136
      */
136
      */
137
-    @PreAuthorize(hasPermi = "monitor:job:changeStatus")
137
+    @RequiresPermissions("monitor:job:changeStatus")
138
     @Log(title = "定时任务", businessType = BusinessType.UPDATE)
138
     @Log(title = "定时任务", businessType = BusinessType.UPDATE)
139
     @PutMapping("/changeStatus")
139
     @PutMapping("/changeStatus")
140
     public AjaxResult changeStatus(@RequestBody SysJob job) throws SchedulerException
140
     public AjaxResult changeStatus(@RequestBody SysJob job) throws SchedulerException
@@ -147,7 +147,7 @@ public class SysJobController extends BaseController
147
     /**
147
     /**
148
      * 定时任务立即执行一次
148
      * 定时任务立即执行一次
149
      */
149
      */
150
-    @PreAuthorize(hasPermi = "monitor:job:changeStatus")
150
+    @RequiresPermissions("monitor:job:changeStatus")
151
     @Log(title = "定时任务", businessType = BusinessType.UPDATE)
151
     @Log(title = "定时任务", businessType = BusinessType.UPDATE)
152
     @PutMapping("/run")
152
     @PutMapping("/run")
153
     public AjaxResult run(@RequestBody SysJob job) throws SchedulerException
153
     public AjaxResult run(@RequestBody SysJob job) throws SchedulerException
@@ -159,7 +159,7 @@ public class SysJobController extends BaseController
159
     /**
159
     /**
160
      * 删除定时任务
160
      * 删除定时任务
161
      */
161
      */
162
-    @PreAuthorize(hasPermi = "monitor:job:remove")
162
+    @RequiresPermissions("monitor:job:remove")
163
     @Log(title = "定时任务", businessType = BusinessType.DELETE)
163
     @Log(title = "定时任务", businessType = BusinessType.DELETE)
164
     @DeleteMapping("/{jobIds}")
164
     @DeleteMapping("/{jobIds}")
165
     public AjaxResult remove(@PathVariable Long[] jobIds) throws SchedulerException, TaskException
165
     public AjaxResult remove(@PathVariable Long[] jobIds) throws SchedulerException, TaskException

+ 6 - 6
ruoyi-modules/ruoyi-job/src/main/java/com/ruoyi/job/controller/SysJobLogController.java

@@ -16,7 +16,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
16
 import com.ruoyi.common.core.web.page.TableDataInfo;
16
 import com.ruoyi.common.core.web.page.TableDataInfo;
17
 import com.ruoyi.common.log.annotation.Log;
17
 import com.ruoyi.common.log.annotation.Log;
18
 import com.ruoyi.common.log.enums.BusinessType;
18
 import com.ruoyi.common.log.enums.BusinessType;
19
-import com.ruoyi.common.security.annotation.PreAuthorize;
19
+import com.ruoyi.common.security.annotation.RequiresPermissions;
20
 import com.ruoyi.job.domain.SysJobLog;
20
 import com.ruoyi.job.domain.SysJobLog;
21
 import com.ruoyi.job.service.ISysJobLogService;
21
 import com.ruoyi.job.service.ISysJobLogService;
22
 
22
 
@@ -35,7 +35,7 @@ public class SysJobLogController extends BaseController
35
     /**
35
     /**
36
      * 查询定时任务调度日志列表
36
      * 查询定时任务调度日志列表
37
      */
37
      */
38
-    @PreAuthorize(hasPermi = "monitor:job:list")
38
+    @RequiresPermissions("monitor:job:list")
39
     @GetMapping("/list")
39
     @GetMapping("/list")
40
     public TableDataInfo list(SysJobLog sysJobLog)
40
     public TableDataInfo list(SysJobLog sysJobLog)
41
     {
41
     {
@@ -47,7 +47,7 @@ public class SysJobLogController extends BaseController
47
     /**
47
     /**
48
      * 导出定时任务调度日志列表
48
      * 导出定时任务调度日志列表
49
      */
49
      */
50
-    @PreAuthorize(hasPermi = "monitor:job:export")
50
+    @RequiresPermissions("monitor:job:export")
51
     @Log(title = "任务调度日志", businessType = BusinessType.EXPORT)
51
     @Log(title = "任务调度日志", businessType = BusinessType.EXPORT)
52
     @PostMapping("/export")
52
     @PostMapping("/export")
53
     public void export(HttpServletResponse response, SysJobLog sysJobLog) throws IOException
53
     public void export(HttpServletResponse response, SysJobLog sysJobLog) throws IOException
@@ -60,7 +60,7 @@ public class SysJobLogController extends BaseController
60
     /**
60
     /**
61
      * 根据调度编号获取详细信息
61
      * 根据调度编号获取详细信息
62
      */
62
      */
63
-    @PreAuthorize(hasPermi = "monitor:job:query")
63
+    @RequiresPermissions("monitor:job:query")
64
     @GetMapping(value = "/{configId}")
64
     @GetMapping(value = "/{configId}")
65
     public AjaxResult getInfo(@PathVariable Long jobLogId)
65
     public AjaxResult getInfo(@PathVariable Long jobLogId)
66
     {
66
     {
@@ -70,7 +70,7 @@ public class SysJobLogController extends BaseController
70
     /**
70
     /**
71
      * 删除定时任务调度日志
71
      * 删除定时任务调度日志
72
      */
72
      */
73
-    @PreAuthorize(hasPermi = "monitor:job:remove")
73
+    @RequiresPermissions("monitor:job:remove")
74
     @Log(title = "定时任务调度日志", businessType = BusinessType.DELETE)
74
     @Log(title = "定时任务调度日志", businessType = BusinessType.DELETE)
75
     @DeleteMapping("/{jobLogIds}")
75
     @DeleteMapping("/{jobLogIds}")
76
     public AjaxResult remove(@PathVariable Long[] jobLogIds)
76
     public AjaxResult remove(@PathVariable Long[] jobLogIds)
@@ -81,7 +81,7 @@ public class SysJobLogController extends BaseController
81
     /**
81
     /**
82
      * 清空定时任务调度日志
82
      * 清空定时任务调度日志
83
      */
83
      */
84
-    @PreAuthorize(hasPermi = "monitor:job:remove")
84
+    @RequiresPermissions("monitor:job:remove")
85
     @Log(title = "调度日志", businessType = BusinessType.CLEAN)
85
     @Log(title = "调度日志", businessType = BusinessType.CLEAN)
86
     @DeleteMapping("/clean")
86
     @DeleteMapping("/clean")
87
     public AjaxResult clean()
87
     public AjaxResult clean()

+ 7 - 7
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysConfigController.java

@@ -21,7 +21,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
22
 import com.ruoyi.common.log.annotation.Log;
22
 import com.ruoyi.common.log.annotation.Log;
23
 import com.ruoyi.common.log.enums.BusinessType;
23
 import com.ruoyi.common.log.enums.BusinessType;
24
-import com.ruoyi.common.security.annotation.PreAuthorize;
24
+import com.ruoyi.common.security.annotation.RequiresPermissions;
25
 import com.ruoyi.system.domain.SysConfig;
25
 import com.ruoyi.system.domain.SysConfig;
26
 import com.ruoyi.system.service.ISysConfigService;
26
 import com.ruoyi.system.service.ISysConfigService;
27
 
27
 
@@ -40,7 +40,7 @@ public class SysConfigController extends BaseController
40
     /**
40
     /**
41
      * 获取参数配置列表
41
      * 获取参数配置列表
42
      */
42
      */
43
-    @PreAuthorize(hasPermi = "system:config:list")
43
+    @RequiresPermissions("system:config:list")
44
     @GetMapping("/list")
44
     @GetMapping("/list")
45
     public TableDataInfo list(SysConfig config)
45
     public TableDataInfo list(SysConfig config)
46
     {
46
     {
@@ -50,7 +50,7 @@ public class SysConfigController extends BaseController
50
     }
50
     }
51
 
51
 
52
     @Log(title = "参数管理", businessType = BusinessType.EXPORT)
52
     @Log(title = "参数管理", businessType = BusinessType.EXPORT)
53
-    @PreAuthorize(hasPermi = "system:config:export")
53
+    @RequiresPermissions("system:config:export")
54
     @PostMapping("/export")
54
     @PostMapping("/export")
55
     public void export(HttpServletResponse response, SysConfig config) throws IOException
55
     public void export(HttpServletResponse response, SysConfig config) throws IOException
56
     {
56
     {
@@ -80,7 +80,7 @@ public class SysConfigController extends BaseController
80
     /**
80
     /**
81
      * 新增参数配置
81
      * 新增参数配置
82
      */
82
      */
83
-    @PreAuthorize(hasPermi = "system:config:add")
83
+    @RequiresPermissions("system:config:add")
84
     @Log(title = "参数管理", businessType = BusinessType.INSERT)
84
     @Log(title = "参数管理", businessType = BusinessType.INSERT)
85
     @PostMapping
85
     @PostMapping
86
     public AjaxResult add(@Validated @RequestBody SysConfig config)
86
     public AjaxResult add(@Validated @RequestBody SysConfig config)
@@ -96,7 +96,7 @@ public class SysConfigController extends BaseController
96
     /**
96
     /**
97
      * 修改参数配置
97
      * 修改参数配置
98
      */
98
      */
99
-    @PreAuthorize(hasPermi = "system:config:edit")
99
+    @RequiresPermissions("system:config:edit")
100
     @Log(title = "参数管理", businessType = BusinessType.UPDATE)
100
     @Log(title = "参数管理", businessType = BusinessType.UPDATE)
101
     @PutMapping
101
     @PutMapping
102
     public AjaxResult edit(@Validated @RequestBody SysConfig config)
102
     public AjaxResult edit(@Validated @RequestBody SysConfig config)
@@ -112,7 +112,7 @@ public class SysConfigController extends BaseController
112
     /**
112
     /**
113
      * 删除参数配置
113
      * 删除参数配置
114
      */
114
      */
115
-    @PreAuthorize(hasPermi = "system:config:remove")
115
+    @RequiresPermissions("system:config:remove")
116
     @Log(title = "参数管理", businessType = BusinessType.DELETE)
116
     @Log(title = "参数管理", businessType = BusinessType.DELETE)
117
     @DeleteMapping("/{configIds}")
117
     @DeleteMapping("/{configIds}")
118
     public AjaxResult remove(@PathVariable Long[] configIds)
118
     public AjaxResult remove(@PathVariable Long[] configIds)
@@ -124,7 +124,7 @@ public class SysConfigController extends BaseController
124
     /**
124
     /**
125
      * 刷新参数缓存
125
      * 刷新参数缓存
126
      */
126
      */
127
-    @PreAuthorize(hasPermi = "system:config:remove")
127
+    @RequiresPermissions("system:config:remove")
128
     @Log(title = "参数管理", businessType = BusinessType.CLEAN)
128
     @Log(title = "参数管理", businessType = BusinessType.CLEAN)
129
     @DeleteMapping("/refreshCache")
129
     @DeleteMapping("/refreshCache")
130
     public AjaxResult refreshCache()
130
     public AjaxResult refreshCache()

+ 7 - 7
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysDeptController.java

@@ -20,7 +20,7 @@ import com.ruoyi.common.core.web.controller.BaseController;
20
 import com.ruoyi.common.core.web.domain.AjaxResult;
20
 import com.ruoyi.common.core.web.domain.AjaxResult;
21
 import com.ruoyi.common.log.annotation.Log;
21
 import com.ruoyi.common.log.annotation.Log;
22
 import com.ruoyi.common.log.enums.BusinessType;
22
 import com.ruoyi.common.log.enums.BusinessType;
23
-import com.ruoyi.common.security.annotation.PreAuthorize;
23
+import com.ruoyi.common.security.annotation.RequiresPermissions;
24
 import com.ruoyi.system.api.domain.SysDept;
24
 import com.ruoyi.system.api.domain.SysDept;
25
 import com.ruoyi.system.service.ISysDeptService;
25
 import com.ruoyi.system.service.ISysDeptService;
26
 
26
 
@@ -39,7 +39,7 @@ public class SysDeptController extends BaseController
39
     /**
39
     /**
40
      * 获取部门列表
40
      * 获取部门列表
41
      */
41
      */
42
-    @PreAuthorize(hasPermi = "system:dept:list")
42
+    @RequiresPermissions("system:dept:list")
43
     @GetMapping("/list")
43
     @GetMapping("/list")
44
     public AjaxResult list(SysDept dept)
44
     public AjaxResult list(SysDept dept)
45
     {
45
     {
@@ -50,7 +50,7 @@ public class SysDeptController extends BaseController
50
     /**
50
     /**
51
      * 查询部门列表(排除节点)
51
      * 查询部门列表(排除节点)
52
      */
52
      */
53
-    @PreAuthorize(hasPermi = "system:dept:list")
53
+    @RequiresPermissions("system:dept:list")
54
     @GetMapping("/list/exclude/{deptId}")
54
     @GetMapping("/list/exclude/{deptId}")
55
     public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId)
55
     public AjaxResult excludeChild(@PathVariable(value = "deptId", required = false) Long deptId)
56
     {
56
     {
@@ -71,7 +71,7 @@ public class SysDeptController extends BaseController
71
     /**
71
     /**
72
      * 根据部门编号获取详细信息
72
      * 根据部门编号获取详细信息
73
      */
73
      */
74
-    @PreAuthorize(hasPermi = "system:dept:query")
74
+    @RequiresPermissions("system:dept:query")
75
     @GetMapping(value = "/{deptId}")
75
     @GetMapping(value = "/{deptId}")
76
     public AjaxResult getInfo(@PathVariable Long deptId)
76
     public AjaxResult getInfo(@PathVariable Long deptId)
77
     {
77
     {
@@ -105,7 +105,7 @@ public class SysDeptController extends BaseController
105
     /**
105
     /**
106
      * 新增部门
106
      * 新增部门
107
      */
107
      */
108
-    @PreAuthorize(hasPermi = "system:dept:add")
108
+    @RequiresPermissions("system:dept:add")
109
     @Log(title = "部门管理", businessType = BusinessType.INSERT)
109
     @Log(title = "部门管理", businessType = BusinessType.INSERT)
110
     @PostMapping
110
     @PostMapping
111
     public AjaxResult add(@Validated @RequestBody SysDept dept)
111
     public AjaxResult add(@Validated @RequestBody SysDept dept)
@@ -121,7 +121,7 @@ public class SysDeptController extends BaseController
121
     /**
121
     /**
122
      * 修改部门
122
      * 修改部门
123
      */
123
      */
124
-    @PreAuthorize(hasPermi = "system:dept:edit")
124
+    @RequiresPermissions("system:dept:edit")
125
     @Log(title = "部门管理", businessType = BusinessType.UPDATE)
125
     @Log(title = "部门管理", businessType = BusinessType.UPDATE)
126
     @PutMapping
126
     @PutMapping
127
     public AjaxResult edit(@Validated @RequestBody SysDept dept)
127
     public AjaxResult edit(@Validated @RequestBody SysDept dept)
@@ -146,7 +146,7 @@ public class SysDeptController extends BaseController
146
     /**
146
     /**
147
      * 删除部门
147
      * 删除部门
148
      */
148
      */
149
-    @PreAuthorize(hasPermi = "system:dept:remove")
149
+    @RequiresPermissions("system:dept:remove")
150
     @Log(title = "部门管理", businessType = BusinessType.DELETE)
150
     @Log(title = "部门管理", businessType = BusinessType.DELETE)
151
     @DeleteMapping("/{deptId}")
151
     @DeleteMapping("/{deptId}")
152
     public AjaxResult remove(@PathVariable Long deptId)
152
     public AjaxResult remove(@PathVariable Long deptId)

+ 7 - 7
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysDictDataController.java

@@ -22,7 +22,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
22
 import com.ruoyi.common.core.web.page.TableDataInfo;
22
 import com.ruoyi.common.core.web.page.TableDataInfo;
23
 import com.ruoyi.common.log.annotation.Log;
23
 import com.ruoyi.common.log.annotation.Log;
24
 import com.ruoyi.common.log.enums.BusinessType;
24
 import com.ruoyi.common.log.enums.BusinessType;
25
-import com.ruoyi.common.security.annotation.PreAuthorize;
25
+import com.ruoyi.common.security.annotation.RequiresPermissions;
26
 import com.ruoyi.system.api.domain.SysDictData;
26
 import com.ruoyi.system.api.domain.SysDictData;
27
 import com.ruoyi.system.service.ISysDictDataService;
27
 import com.ruoyi.system.service.ISysDictDataService;
28
 import com.ruoyi.system.service.ISysDictTypeService;
28
 import com.ruoyi.system.service.ISysDictTypeService;
@@ -42,7 +42,7 @@ public class SysDictDataController extends BaseController
42
     @Autowired
42
     @Autowired
43
     private ISysDictTypeService dictTypeService;
43
     private ISysDictTypeService dictTypeService;
44
 
44
 
45
-    @PreAuthorize(hasPermi = "system:dict:list")
45
+    @RequiresPermissions("system:dict:list")
46
     @GetMapping("/list")
46
     @GetMapping("/list")
47
     public TableDataInfo list(SysDictData dictData)
47
     public TableDataInfo list(SysDictData dictData)
48
     {
48
     {
@@ -52,7 +52,7 @@ public class SysDictDataController extends BaseController
52
     }
52
     }
53
 
53
 
54
     @Log(title = "字典数据", businessType = BusinessType.EXPORT)
54
     @Log(title = "字典数据", businessType = BusinessType.EXPORT)
55
-    @PreAuthorize(hasPermi = "system:dict:export")
55
+    @RequiresPermissions("system:dict:export")
56
     @PostMapping("/export")
56
     @PostMapping("/export")
57
     public void export(HttpServletResponse response, SysDictData dictData) throws IOException
57
     public void export(HttpServletResponse response, SysDictData dictData) throws IOException
58
     {
58
     {
@@ -64,7 +64,7 @@ public class SysDictDataController extends BaseController
64
     /**
64
     /**
65
      * 查询字典数据详细
65
      * 查询字典数据详细
66
      */
66
      */
67
-    @PreAuthorize(hasPermi = "system:dict:query")
67
+    @RequiresPermissions("system:dict:query")
68
     @GetMapping(value = "/{dictCode}")
68
     @GetMapping(value = "/{dictCode}")
69
     public AjaxResult getInfo(@PathVariable Long dictCode)
69
     public AjaxResult getInfo(@PathVariable Long dictCode)
70
     {
70
     {
@@ -88,7 +88,7 @@ public class SysDictDataController extends BaseController
88
     /**
88
     /**
89
      * 新增字典类型
89
      * 新增字典类型
90
      */
90
      */
91
-    @PreAuthorize(hasPermi = "system:dict:add")
91
+    @RequiresPermissions("system:dict:add")
92
     @Log(title = "字典数据", businessType = BusinessType.INSERT)
92
     @Log(title = "字典数据", businessType = BusinessType.INSERT)
93
     @PostMapping
93
     @PostMapping
94
     public AjaxResult add(@Validated @RequestBody SysDictData dict)
94
     public AjaxResult add(@Validated @RequestBody SysDictData dict)
@@ -100,7 +100,7 @@ public class SysDictDataController extends BaseController
100
     /**
100
     /**
101
      * 修改保存字典类型
101
      * 修改保存字典类型
102
      */
102
      */
103
-    @PreAuthorize(hasPermi = "system:dict:edit")
103
+    @RequiresPermissions("system:dict:edit")
104
     @Log(title = "字典数据", businessType = BusinessType.UPDATE)
104
     @Log(title = "字典数据", businessType = BusinessType.UPDATE)
105
     @PutMapping
105
     @PutMapping
106
     public AjaxResult edit(@Validated @RequestBody SysDictData dict)
106
     public AjaxResult edit(@Validated @RequestBody SysDictData dict)
@@ -112,7 +112,7 @@ public class SysDictDataController extends BaseController
112
     /**
112
     /**
113
      * 删除字典类型
113
      * 删除字典类型
114
      */
114
      */
115
-    @PreAuthorize(hasPermi = "system:dict:remove")
115
+    @RequiresPermissions("system:dict:remove")
116
     @Log(title = "字典类型", businessType = BusinessType.DELETE)
116
     @Log(title = "字典类型", businessType = BusinessType.DELETE)
117
     @DeleteMapping("/{dictCodes}")
117
     @DeleteMapping("/{dictCodes}")
118
     public AjaxResult remove(@PathVariable Long[] dictCodes)
118
     public AjaxResult remove(@PathVariable Long[] dictCodes)

+ 8 - 8
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysDictTypeController.java

@@ -21,7 +21,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
22
 import com.ruoyi.common.log.annotation.Log;
22
 import com.ruoyi.common.log.annotation.Log;
23
 import com.ruoyi.common.log.enums.BusinessType;
23
 import com.ruoyi.common.log.enums.BusinessType;
24
-import com.ruoyi.common.security.annotation.PreAuthorize;
24
+import com.ruoyi.common.security.annotation.RequiresPermissions;
25
 import com.ruoyi.system.api.domain.SysDictType;
25
 import com.ruoyi.system.api.domain.SysDictType;
26
 import com.ruoyi.system.service.ISysDictTypeService;
26
 import com.ruoyi.system.service.ISysDictTypeService;
27
 
27
 
@@ -37,7 +37,7 @@ public class SysDictTypeController extends BaseController
37
     @Autowired
37
     @Autowired
38
     private ISysDictTypeService dictTypeService;
38
     private ISysDictTypeService dictTypeService;
39
 
39
 
40
-    @PreAuthorize(hasPermi = "system:dict:list")
40
+    @RequiresPermissions("system:dict:list")
41
     @GetMapping("/list")
41
     @GetMapping("/list")
42
     public TableDataInfo list(SysDictType dictType)
42
     public TableDataInfo list(SysDictType dictType)
43
     {
43
     {
@@ -47,7 +47,7 @@ public class SysDictTypeController extends BaseController
47
     }
47
     }
48
 
48
 
49
     @Log(title = "字典类型", businessType = BusinessType.EXPORT)
49
     @Log(title = "字典类型", businessType = BusinessType.EXPORT)
50
-    @PreAuthorize(hasPermi = "system:dict:export")
50
+    @RequiresPermissions("system:dict:export")
51
     @PostMapping("/export")
51
     @PostMapping("/export")
52
     public void export(HttpServletResponse response, SysDictType dictType) throws IOException
52
     public void export(HttpServletResponse response, SysDictType dictType) throws IOException
53
     {
53
     {
@@ -59,7 +59,7 @@ public class SysDictTypeController extends BaseController
59
     /**
59
     /**
60
      * 查询字典类型详细
60
      * 查询字典类型详细
61
      */
61
      */
62
-    @PreAuthorize(hasPermi = "system:dict:query")
62
+    @RequiresPermissions("system:dict:query")
63
     @GetMapping(value = "/{dictId}")
63
     @GetMapping(value = "/{dictId}")
64
     public AjaxResult getInfo(@PathVariable Long dictId)
64
     public AjaxResult getInfo(@PathVariable Long dictId)
65
     {
65
     {
@@ -69,7 +69,7 @@ public class SysDictTypeController extends BaseController
69
     /**
69
     /**
70
      * 新增字典类型
70
      * 新增字典类型
71
      */
71
      */
72
-    @PreAuthorize(hasPermi = "system:dict:add")
72
+    @RequiresPermissions("system:dict:add")
73
     @Log(title = "字典类型", businessType = BusinessType.INSERT)
73
     @Log(title = "字典类型", businessType = BusinessType.INSERT)
74
     @PostMapping
74
     @PostMapping
75
     public AjaxResult add(@Validated @RequestBody SysDictType dict)
75
     public AjaxResult add(@Validated @RequestBody SysDictType dict)
@@ -85,7 +85,7 @@ public class SysDictTypeController extends BaseController
85
     /**
85
     /**
86
      * 修改字典类型
86
      * 修改字典类型
87
      */
87
      */
88
-    @PreAuthorize(hasPermi = "system:dict:edit")
88
+    @RequiresPermissions("system:dict:edit")
89
     @Log(title = "字典类型", businessType = BusinessType.UPDATE)
89
     @Log(title = "字典类型", businessType = BusinessType.UPDATE)
90
     @PutMapping
90
     @PutMapping
91
     public AjaxResult edit(@Validated @RequestBody SysDictType dict)
91
     public AjaxResult edit(@Validated @RequestBody SysDictType dict)
@@ -101,7 +101,7 @@ public class SysDictTypeController extends BaseController
101
     /**
101
     /**
102
      * 删除字典类型
102
      * 删除字典类型
103
      */
103
      */
104
-    @PreAuthorize(hasPermi = "system:dict:remove")
104
+    @RequiresPermissions("system:dict:remove")
105
     @Log(title = "字典类型", businessType = BusinessType.DELETE)
105
     @Log(title = "字典类型", businessType = BusinessType.DELETE)
106
     @DeleteMapping("/{dictIds}")
106
     @DeleteMapping("/{dictIds}")
107
     public AjaxResult remove(@PathVariable Long[] dictIds)
107
     public AjaxResult remove(@PathVariable Long[] dictIds)
@@ -113,7 +113,7 @@ public class SysDictTypeController extends BaseController
113
     /**
113
     /**
114
      * 刷新字典缓存
114
      * 刷新字典缓存
115
      */
115
      */
116
-    @PreAuthorize(hasPermi = "system:dict:remove")
116
+    @RequiresPermissions("system:dict:remove")
117
     @Log(title = "字典类型", businessType = BusinessType.CLEAN)
117
     @Log(title = "字典类型", businessType = BusinessType.CLEAN)
118
     @DeleteMapping("/refreshCache")
118
     @DeleteMapping("/refreshCache")
119
     public AjaxResult refreshCache()
119
     public AjaxResult refreshCache()

+ 5 - 5
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysLogininforController.java

@@ -18,7 +18,7 @@ import com.ruoyi.common.core.web.page.TableDataInfo;
18
 import com.ruoyi.common.log.annotation.Log;
18
 import com.ruoyi.common.log.annotation.Log;
19
 import com.ruoyi.common.log.enums.BusinessType;
19
 import com.ruoyi.common.log.enums.BusinessType;
20
 import com.ruoyi.common.security.annotation.InnerAuth;
20
 import com.ruoyi.common.security.annotation.InnerAuth;
21
-import com.ruoyi.common.security.annotation.PreAuthorize;
21
+import com.ruoyi.common.security.annotation.RequiresPermissions;
22
 import com.ruoyi.system.api.domain.SysLogininfor;
22
 import com.ruoyi.system.api.domain.SysLogininfor;
23
 import com.ruoyi.system.service.ISysLogininforService;
23
 import com.ruoyi.system.service.ISysLogininforService;
24
 
24
 
@@ -34,7 +34,7 @@ public class SysLogininforController extends BaseController
34
     @Autowired
34
     @Autowired
35
     private ISysLogininforService logininforService;
35
     private ISysLogininforService logininforService;
36
 
36
 
37
-    @PreAuthorize(hasPermi = "system:logininfor:list")
37
+    @RequiresPermissions("system:logininfor:list")
38
     @GetMapping("/list")
38
     @GetMapping("/list")
39
     public TableDataInfo list(SysLogininfor logininfor)
39
     public TableDataInfo list(SysLogininfor logininfor)
40
     {
40
     {
@@ -44,7 +44,7 @@ public class SysLogininforController extends BaseController
44
     }
44
     }
45
 
45
 
46
     @Log(title = "登录日志", businessType = BusinessType.EXPORT)
46
     @Log(title = "登录日志", businessType = BusinessType.EXPORT)
47
-    @PreAuthorize(hasPermi = "system:logininfor:export")
47
+    @RequiresPermissions("system:logininfor:export")
48
     @PostMapping("/export")
48
     @PostMapping("/export")
49
     public void export(HttpServletResponse response, SysLogininfor logininfor) throws IOException
49
     public void export(HttpServletResponse response, SysLogininfor logininfor) throws IOException
50
     {
50
     {
@@ -53,7 +53,7 @@ public class SysLogininforController extends BaseController
53
         util.exportExcel(response, list, "登录日志");
53
         util.exportExcel(response, list, "登录日志");
54
     }
54
     }
55
 
55
 
56
-    @PreAuthorize(hasPermi = "system:logininfor:remove")
56
+    @RequiresPermissions("system:logininfor:remove")
57
     @Log(title = "登录日志", businessType = BusinessType.DELETE)
57
     @Log(title = "登录日志", businessType = BusinessType.DELETE)
58
     @DeleteMapping("/{infoIds}")
58
     @DeleteMapping("/{infoIds}")
59
     public AjaxResult remove(@PathVariable Long[] infoIds)
59
     public AjaxResult remove(@PathVariable Long[] infoIds)
@@ -61,7 +61,7 @@ public class SysLogininforController extends BaseController
61
         return toAjax(logininforService.deleteLogininforByIds(infoIds));
61
         return toAjax(logininforService.deleteLogininforByIds(infoIds));
62
     }
62
     }
63
 
63
 
64
-    @PreAuthorize(hasPermi = "system:logininfor:remove")
64
+    @RequiresPermissions("system:logininfor:remove")
65
     @Log(title = "登录日志", businessType = BusinessType.DELETE)
65
     @Log(title = "登录日志", businessType = BusinessType.DELETE)
66
     @DeleteMapping("/clean")
66
     @DeleteMapping("/clean")
67
     public AjaxResult clean()
67
     public AjaxResult clean()

+ 6 - 6
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysMenuController.java

@@ -18,7 +18,7 @@ import com.ruoyi.common.core.web.controller.BaseController;
18
 import com.ruoyi.common.core.web.domain.AjaxResult;
18
 import com.ruoyi.common.core.web.domain.AjaxResult;
19
 import com.ruoyi.common.log.annotation.Log;
19
 import com.ruoyi.common.log.annotation.Log;
20
 import com.ruoyi.common.log.enums.BusinessType;
20
 import com.ruoyi.common.log.enums.BusinessType;
21
-import com.ruoyi.common.security.annotation.PreAuthorize;
21
+import com.ruoyi.common.security.annotation.RequiresPermissions;
22
 import com.ruoyi.system.domain.SysMenu;
22
 import com.ruoyi.system.domain.SysMenu;
23
 import com.ruoyi.system.service.ISysMenuService;
23
 import com.ruoyi.system.service.ISysMenuService;
24
 
24
 
@@ -37,7 +37,7 @@ public class SysMenuController extends BaseController
37
     /**
37
     /**
38
      * 获取菜单列表
38
      * 获取菜单列表
39
      */
39
      */
40
-    @PreAuthorize(hasPermi = "system:menu:list")
40
+    @RequiresPermissions("system:menu:list")
41
     @GetMapping("/list")
41
     @GetMapping("/list")
42
     public AjaxResult list(SysMenu menu)
42
     public AjaxResult list(SysMenu menu)
43
     {
43
     {
@@ -49,7 +49,7 @@ public class SysMenuController extends BaseController
49
     /**
49
     /**
50
      * 根据菜单编号获取详细信息
50
      * 根据菜单编号获取详细信息
51
      */
51
      */
52
-    @PreAuthorize(hasPermi = "system:menu:query")
52
+    @RequiresPermissions("system:menu:query")
53
     @GetMapping(value = "/{menuId}")
53
     @GetMapping(value = "/{menuId}")
54
     public AjaxResult getInfo(@PathVariable Long menuId)
54
     public AjaxResult getInfo(@PathVariable Long menuId)
55
     {
55
     {
@@ -84,7 +84,7 @@ public class SysMenuController extends BaseController
84
     /**
84
     /**
85
      * 新增菜单
85
      * 新增菜单
86
      */
86
      */
87
-    @PreAuthorize(hasPermi = "system:menu:add")
87
+    @RequiresPermissions("system:menu:add")
88
     @Log(title = "菜单管理", businessType = BusinessType.INSERT)
88
     @Log(title = "菜单管理", businessType = BusinessType.INSERT)
89
     @PostMapping
89
     @PostMapping
90
     public AjaxResult add(@Validated @RequestBody SysMenu menu)
90
     public AjaxResult add(@Validated @RequestBody SysMenu menu)
@@ -104,7 +104,7 @@ public class SysMenuController extends BaseController
104
     /**
104
     /**
105
      * 修改菜单
105
      * 修改菜单
106
      */
106
      */
107
-    @PreAuthorize(hasPermi = "system:menu:edit")
107
+    @RequiresPermissions("system:menu:edit")
108
     @Log(title = "菜单管理", businessType = BusinessType.UPDATE)
108
     @Log(title = "菜单管理", businessType = BusinessType.UPDATE)
109
     @PutMapping
109
     @PutMapping
110
     public AjaxResult edit(@Validated @RequestBody SysMenu menu)
110
     public AjaxResult edit(@Validated @RequestBody SysMenu menu)
@@ -128,7 +128,7 @@ public class SysMenuController extends BaseController
128
     /**
128
     /**
129
      * 删除菜单
129
      * 删除菜单
130
      */
130
      */
131
-    @PreAuthorize(hasPermi = "system:menu:remove")
131
+    @RequiresPermissions("system:menu:remove")
132
     @Log(title = "菜单管理", businessType = BusinessType.DELETE)
132
     @Log(title = "菜单管理", businessType = BusinessType.DELETE)
133
     @DeleteMapping("/{menuId}")
133
     @DeleteMapping("/{menuId}")
134
     public AjaxResult remove(@PathVariable("menuId") Long menuId)
134
     public AjaxResult remove(@PathVariable("menuId") Long menuId)

+ 6 - 6
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysNoticeController.java

@@ -17,7 +17,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
17
 import com.ruoyi.common.core.web.page.TableDataInfo;
17
 import com.ruoyi.common.core.web.page.TableDataInfo;
18
 import com.ruoyi.common.log.annotation.Log;
18
 import com.ruoyi.common.log.annotation.Log;
19
 import com.ruoyi.common.log.enums.BusinessType;
19
 import com.ruoyi.common.log.enums.BusinessType;
20
-import com.ruoyi.common.security.annotation.PreAuthorize;
20
+import com.ruoyi.common.security.annotation.RequiresPermissions;
21
 import com.ruoyi.system.domain.SysNotice;
21
 import com.ruoyi.system.domain.SysNotice;
22
 import com.ruoyi.system.service.ISysNoticeService;
22
 import com.ruoyi.system.service.ISysNoticeService;
23
 
23
 
@@ -36,7 +36,7 @@ public class SysNoticeController extends BaseController
36
     /**
36
     /**
37
      * 获取通知公告列表
37
      * 获取通知公告列表
38
      */
38
      */
39
-    @PreAuthorize(hasPermi = "system:notice:list")
39
+    @RequiresPermissions("system:notice:list")
40
     @GetMapping("/list")
40
     @GetMapping("/list")
41
     public TableDataInfo list(SysNotice notice)
41
     public TableDataInfo list(SysNotice notice)
42
     {
42
     {
@@ -48,7 +48,7 @@ public class SysNoticeController extends BaseController
48
     /**
48
     /**
49
      * 根据通知公告编号获取详细信息
49
      * 根据通知公告编号获取详细信息
50
      */
50
      */
51
-    @PreAuthorize(hasPermi = "system:notice:query")
51
+    @RequiresPermissions("system:notice:query")
52
     @GetMapping(value = "/{noticeId}")
52
     @GetMapping(value = "/{noticeId}")
53
     public AjaxResult getInfo(@PathVariable Long noticeId)
53
     public AjaxResult getInfo(@PathVariable Long noticeId)
54
     {
54
     {
@@ -58,7 +58,7 @@ public class SysNoticeController extends BaseController
58
     /**
58
     /**
59
      * 新增通知公告
59
      * 新增通知公告
60
      */
60
      */
61
-    @PreAuthorize(hasPermi = "system:notice:add")
61
+    @RequiresPermissions("system:notice:add")
62
     @Log(title = "通知公告", businessType = BusinessType.INSERT)
62
     @Log(title = "通知公告", businessType = BusinessType.INSERT)
63
     @PostMapping
63
     @PostMapping
64
     public AjaxResult add(@Validated @RequestBody SysNotice notice)
64
     public AjaxResult add(@Validated @RequestBody SysNotice notice)
@@ -70,7 +70,7 @@ public class SysNoticeController extends BaseController
70
     /**
70
     /**
71
      * 修改通知公告
71
      * 修改通知公告
72
      */
72
      */
73
-    @PreAuthorize(hasPermi = "system:notice:edit")
73
+    @RequiresPermissions("system:notice:edit")
74
     @Log(title = "通知公告", businessType = BusinessType.UPDATE)
74
     @Log(title = "通知公告", businessType = BusinessType.UPDATE)
75
     @PutMapping
75
     @PutMapping
76
     public AjaxResult edit(@Validated @RequestBody SysNotice notice)
76
     public AjaxResult edit(@Validated @RequestBody SysNotice notice)
@@ -82,7 +82,7 @@ public class SysNoticeController extends BaseController
82
     /**
82
     /**
83
      * 删除通知公告
83
      * 删除通知公告
84
      */
84
      */
85
-    @PreAuthorize(hasPermi = "system:notice:remove")
85
+    @RequiresPermissions("system:notice:remove")
86
     @Log(title = "通知公告", businessType = BusinessType.DELETE)
86
     @Log(title = "通知公告", businessType = BusinessType.DELETE)
87
     @DeleteMapping("/{noticeIds}")
87
     @DeleteMapping("/{noticeIds}")
88
     public AjaxResult remove(@PathVariable Long[] noticeIds)
88
     public AjaxResult remove(@PathVariable Long[] noticeIds)

+ 5 - 5
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysOperlogController.java

@@ -18,7 +18,7 @@ import com.ruoyi.common.core.web.page.TableDataInfo;
18
 import com.ruoyi.common.log.annotation.Log;
18
 import com.ruoyi.common.log.annotation.Log;
19
 import com.ruoyi.common.log.enums.BusinessType;
19
 import com.ruoyi.common.log.enums.BusinessType;
20
 import com.ruoyi.common.security.annotation.InnerAuth;
20
 import com.ruoyi.common.security.annotation.InnerAuth;
21
-import com.ruoyi.common.security.annotation.PreAuthorize;
21
+import com.ruoyi.common.security.annotation.RequiresPermissions;
22
 import com.ruoyi.system.api.domain.SysOperLog;
22
 import com.ruoyi.system.api.domain.SysOperLog;
23
 import com.ruoyi.system.service.ISysOperLogService;
23
 import com.ruoyi.system.service.ISysOperLogService;
24
 
24
 
@@ -34,7 +34,7 @@ public class SysOperlogController extends BaseController
34
     @Autowired
34
     @Autowired
35
     private ISysOperLogService operLogService;
35
     private ISysOperLogService operLogService;
36
 
36
 
37
-    @PreAuthorize(hasPermi = "system:operlog:list")
37
+    @RequiresPermissions("system:operlog:list")
38
     @GetMapping("/list")
38
     @GetMapping("/list")
39
     public TableDataInfo list(SysOperLog operLog)
39
     public TableDataInfo list(SysOperLog operLog)
40
     {
40
     {
@@ -44,7 +44,7 @@ public class SysOperlogController extends BaseController
44
     }
44
     }
45
 
45
 
46
     @Log(title = "操作日志", businessType = BusinessType.EXPORT)
46
     @Log(title = "操作日志", businessType = BusinessType.EXPORT)
47
-    @PreAuthorize(hasPermi = "system:operlog:export")
47
+    @RequiresPermissions("system:operlog:export")
48
     @PostMapping("/export")
48
     @PostMapping("/export")
49
     public void export(HttpServletResponse response, SysOperLog operLog) throws IOException
49
     public void export(HttpServletResponse response, SysOperLog operLog) throws IOException
50
     {
50
     {
@@ -54,14 +54,14 @@ public class SysOperlogController extends BaseController
54
     }
54
     }
55
 
55
 
56
     @Log(title = "操作日志", businessType = BusinessType.DELETE)
56
     @Log(title = "操作日志", businessType = BusinessType.DELETE)
57
-    @PreAuthorize(hasPermi = "system:operlog:remove")
57
+    @RequiresPermissions("system:operlog:remove")
58
     @DeleteMapping("/{operIds}")
58
     @DeleteMapping("/{operIds}")
59
     public AjaxResult remove(@PathVariable Long[] operIds)
59
     public AjaxResult remove(@PathVariable Long[] operIds)
60
     {
60
     {
61
         return toAjax(operLogService.deleteOperLogByIds(operIds));
61
         return toAjax(operLogService.deleteOperLogByIds(operIds));
62
     }
62
     }
63
 
63
 
64
-    @PreAuthorize(hasPermi = "system:operlog:remove")
64
+    @RequiresPermissions("system:operlog:remove")
65
     @Log(title = "操作日志", businessType = BusinessType.CLEAN)
65
     @Log(title = "操作日志", businessType = BusinessType.CLEAN)
66
     @DeleteMapping("/clean")
66
     @DeleteMapping("/clean")
67
     public AjaxResult clean()
67
     public AjaxResult clean()

+ 7 - 7
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysPostController.java

@@ -21,7 +21,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
22
 import com.ruoyi.common.log.annotation.Log;
22
 import com.ruoyi.common.log.annotation.Log;
23
 import com.ruoyi.common.log.enums.BusinessType;
23
 import com.ruoyi.common.log.enums.BusinessType;
24
-import com.ruoyi.common.security.annotation.PreAuthorize;
24
+import com.ruoyi.common.security.annotation.RequiresPermissions;
25
 import com.ruoyi.system.domain.SysPost;
25
 import com.ruoyi.system.domain.SysPost;
26
 import com.ruoyi.system.service.ISysPostService;
26
 import com.ruoyi.system.service.ISysPostService;
27
 
27
 
@@ -40,7 +40,7 @@ public class SysPostController extends BaseController
40
     /**
40
     /**
41
      * 获取岗位列表
41
      * 获取岗位列表
42
      */
42
      */
43
-    @PreAuthorize(hasPermi = "system:post:list")
43
+    @RequiresPermissions("system:post:list")
44
     @GetMapping("/list")
44
     @GetMapping("/list")
45
     public TableDataInfo list(SysPost post)
45
     public TableDataInfo list(SysPost post)
46
     {
46
     {
@@ -50,7 +50,7 @@ public class SysPostController extends BaseController
50
     }
50
     }
51
 
51
 
52
     @Log(title = "岗位管理", businessType = BusinessType.EXPORT)
52
     @Log(title = "岗位管理", businessType = BusinessType.EXPORT)
53
-    @PreAuthorize(hasPermi = "system:post:export")
53
+    @RequiresPermissions("system:post:export")
54
     @PostMapping("/export")
54
     @PostMapping("/export")
55
     public void export(HttpServletResponse response, SysPost post) throws IOException
55
     public void export(HttpServletResponse response, SysPost post) throws IOException
56
     {
56
     {
@@ -62,7 +62,7 @@ public class SysPostController extends BaseController
62
     /**
62
     /**
63
      * 根据岗位编号获取详细信息
63
      * 根据岗位编号获取详细信息
64
      */
64
      */
65
-    @PreAuthorize(hasPermi = "system:post:query")
65
+    @RequiresPermissions("system:post:query")
66
     @GetMapping(value = "/{postId}")
66
     @GetMapping(value = "/{postId}")
67
     public AjaxResult getInfo(@PathVariable Long postId)
67
     public AjaxResult getInfo(@PathVariable Long postId)
68
     {
68
     {
@@ -72,7 +72,7 @@ public class SysPostController extends BaseController
72
     /**
72
     /**
73
      * 新增岗位
73
      * 新增岗位
74
      */
74
      */
75
-    @PreAuthorize(hasPermi = "system:post:add")
75
+    @RequiresPermissions("system:post:add")
76
     @Log(title = "岗位管理", businessType = BusinessType.INSERT)
76
     @Log(title = "岗位管理", businessType = BusinessType.INSERT)
77
     @PostMapping
77
     @PostMapping
78
     public AjaxResult add(@Validated @RequestBody SysPost post)
78
     public AjaxResult add(@Validated @RequestBody SysPost post)
@@ -92,7 +92,7 @@ public class SysPostController extends BaseController
92
     /**
92
     /**
93
      * 修改岗位
93
      * 修改岗位
94
      */
94
      */
95
-    @PreAuthorize(hasPermi = "system:post:edit")
95
+    @RequiresPermissions("system:post:edit")
96
     @Log(title = "岗位管理", businessType = BusinessType.UPDATE)
96
     @Log(title = "岗位管理", businessType = BusinessType.UPDATE)
97
     @PutMapping
97
     @PutMapping
98
     public AjaxResult edit(@Validated @RequestBody SysPost post)
98
     public AjaxResult edit(@Validated @RequestBody SysPost post)
@@ -112,7 +112,7 @@ public class SysPostController extends BaseController
112
     /**
112
     /**
113
      * 删除岗位
113
      * 删除岗位
114
      */
114
      */
115
-    @PreAuthorize(hasPermi = "system:post:remove")
115
+    @RequiresPermissions("system:post:remove")
116
     @Log(title = "岗位管理", businessType = BusinessType.DELETE)
116
     @Log(title = "岗位管理", businessType = BusinessType.DELETE)
117
     @DeleteMapping("/{postIds}")
117
     @DeleteMapping("/{postIds}")
118
     public AjaxResult remove(@PathVariable Long[] postIds)
118
     public AjaxResult remove(@PathVariable Long[] postIds)

+ 15 - 15
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysRoleController.java

@@ -21,7 +21,7 @@ import com.ruoyi.common.core.web.domain.AjaxResult;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
21
 import com.ruoyi.common.core.web.page.TableDataInfo;
22
 import com.ruoyi.common.log.annotation.Log;
22
 import com.ruoyi.common.log.annotation.Log;
23
 import com.ruoyi.common.log.enums.BusinessType;
23
 import com.ruoyi.common.log.enums.BusinessType;
24
-import com.ruoyi.common.security.annotation.PreAuthorize;
24
+import com.ruoyi.common.security.annotation.RequiresPermissions;
25
 import com.ruoyi.system.api.domain.SysRole;
25
 import com.ruoyi.system.api.domain.SysRole;
26
 import com.ruoyi.system.api.domain.SysUser;
26
 import com.ruoyi.system.api.domain.SysUser;
27
 import com.ruoyi.system.domain.SysUserRole;
27
 import com.ruoyi.system.domain.SysUserRole;
@@ -43,7 +43,7 @@ public class SysRoleController extends BaseController
43
     @Autowired
43
     @Autowired
44
     private ISysUserService userService;
44
     private ISysUserService userService;
45
 
45
 
46
-    @PreAuthorize(hasPermi = "system:role:list")
46
+    @RequiresPermissions("system:role:list")
47
     @GetMapping("/list")
47
     @GetMapping("/list")
48
     public TableDataInfo list(SysRole role)
48
     public TableDataInfo list(SysRole role)
49
     {
49
     {
@@ -53,7 +53,7 @@ public class SysRoleController extends BaseController
53
     }
53
     }
54
 
54
 
55
     @Log(title = "角色管理", businessType = BusinessType.EXPORT)
55
     @Log(title = "角色管理", businessType = BusinessType.EXPORT)
56
-    @PreAuthorize(hasPermi = "system:role:export")
56
+    @RequiresPermissions("system:role:export")
57
     @PostMapping("/export")
57
     @PostMapping("/export")
58
     public void export(HttpServletResponse response, SysRole role) throws IOException
58
     public void export(HttpServletResponse response, SysRole role) throws IOException
59
     {
59
     {
@@ -65,7 +65,7 @@ public class SysRoleController extends BaseController
65
     /**
65
     /**
66
      * 根据角色编号获取详细信息
66
      * 根据角色编号获取详细信息
67
      */
67
      */
68
-    @PreAuthorize(hasPermi = "system:role:query")
68
+    @RequiresPermissions("system:role:query")
69
     @GetMapping(value = "/{roleId}")
69
     @GetMapping(value = "/{roleId}")
70
     public AjaxResult getInfo(@PathVariable Long roleId)
70
     public AjaxResult getInfo(@PathVariable Long roleId)
71
     {
71
     {
@@ -76,7 +76,7 @@ public class SysRoleController extends BaseController
76
     /**
76
     /**
77
      * 新增角色
77
      * 新增角色
78
      */
78
      */
79
-    @PreAuthorize(hasPermi = "system:role:add")
79
+    @RequiresPermissions("system:role:add")
80
     @Log(title = "角色管理", businessType = BusinessType.INSERT)
80
     @Log(title = "角色管理", businessType = BusinessType.INSERT)
81
     @PostMapping
81
     @PostMapping
82
     public AjaxResult add(@Validated @RequestBody SysRole role)
82
     public AjaxResult add(@Validated @RequestBody SysRole role)
@@ -97,7 +97,7 @@ public class SysRoleController extends BaseController
97
     /**
97
     /**
98
      * 修改保存角色
98
      * 修改保存角色
99
      */
99
      */
100
-    @PreAuthorize(hasPermi = "system:role:edit")
100
+    @RequiresPermissions("system:role:edit")
101
     @Log(title = "角色管理", businessType = BusinessType.UPDATE)
101
     @Log(title = "角色管理", businessType = BusinessType.UPDATE)
102
     @PutMapping
102
     @PutMapping
103
     public AjaxResult edit(@Validated @RequestBody SysRole role)
103
     public AjaxResult edit(@Validated @RequestBody SysRole role)
@@ -118,7 +118,7 @@ public class SysRoleController extends BaseController
118
     /**
118
     /**
119
      * 修改保存数据权限
119
      * 修改保存数据权限
120
      */
120
      */
121
-    @PreAuthorize(hasPermi = "system:role:edit")
121
+    @RequiresPermissions("system:role:edit")
122
     @Log(title = "角色管理", businessType = BusinessType.UPDATE)
122
     @Log(title = "角色管理", businessType = BusinessType.UPDATE)
123
     @PutMapping("/dataScope")
123
     @PutMapping("/dataScope")
124
     public AjaxResult dataScope(@RequestBody SysRole role)
124
     public AjaxResult dataScope(@RequestBody SysRole role)
@@ -130,7 +130,7 @@ public class SysRoleController extends BaseController
130
     /**
130
     /**
131
      * 状态修改
131
      * 状态修改
132
      */
132
      */
133
-    @PreAuthorize(hasPermi = "system:role:edit")
133
+    @RequiresPermissions("system:role:edit")
134
     @Log(title = "角色管理", businessType = BusinessType.UPDATE)
134
     @Log(title = "角色管理", businessType = BusinessType.UPDATE)
135
     @PutMapping("/changeStatus")
135
     @PutMapping("/changeStatus")
136
     public AjaxResult changeStatus(@RequestBody SysRole role)
136
     public AjaxResult changeStatus(@RequestBody SysRole role)
@@ -143,7 +143,7 @@ public class SysRoleController extends BaseController
143
     /**
143
     /**
144
      * 删除角色
144
      * 删除角色
145
      */
145
      */
146
-    @PreAuthorize(hasPermi = "system:role:remove")
146
+    @RequiresPermissions("system:role:remove")
147
     @Log(title = "角色管理", businessType = BusinessType.DELETE)
147
     @Log(title = "角色管理", businessType = BusinessType.DELETE)
148
     @DeleteMapping("/{roleIds}")
148
     @DeleteMapping("/{roleIds}")
149
     public AjaxResult remove(@PathVariable Long[] roleIds)
149
     public AjaxResult remove(@PathVariable Long[] roleIds)
@@ -154,7 +154,7 @@ public class SysRoleController extends BaseController
154
     /**
154
     /**
155
      * 获取角色选择框列表
155
      * 获取角色选择框列表
156
      */
156
      */
157
-    @PreAuthorize(hasPermi = "system:role:query")
157
+    @RequiresPermissions("system:role:query")
158
     @GetMapping("/optionselect")
158
     @GetMapping("/optionselect")
159
     public AjaxResult optionselect()
159
     public AjaxResult optionselect()
160
     {
160
     {
@@ -163,7 +163,7 @@ public class SysRoleController extends BaseController
163
     /**
163
     /**
164
      * 查询已分配用户角色列表
164
      * 查询已分配用户角色列表
165
      */
165
      */
166
-    @PreAuthorize(hasPermi = "system:role:list")
166
+    @RequiresPermissions("system:role:list")
167
     @GetMapping("/authUser/allocatedList")
167
     @GetMapping("/authUser/allocatedList")
168
     public TableDataInfo allocatedList(SysUser user)
168
     public TableDataInfo allocatedList(SysUser user)
169
     {
169
     {
@@ -175,7 +175,7 @@ public class SysRoleController extends BaseController
175
     /**
175
     /**
176
      * 查询未分配用户角色列表
176
      * 查询未分配用户角色列表
177
      */
177
      */
178
-    @PreAuthorize(hasPermi = "system:role:list")
178
+    @RequiresPermissions("system:role:list")
179
     @GetMapping("/authUser/unallocatedList")
179
     @GetMapping("/authUser/unallocatedList")
180
     public TableDataInfo unallocatedList(SysUser user)
180
     public TableDataInfo unallocatedList(SysUser user)
181
     {
181
     {
@@ -187,7 +187,7 @@ public class SysRoleController extends BaseController
187
     /**
187
     /**
188
      * 取消授权用户
188
      * 取消授权用户
189
      */
189
      */
190
-    @PreAuthorize(hasPermi = "system:role:edit")
190
+    @RequiresPermissions("system:role:edit")
191
     @Log(title = "角色管理", businessType = BusinessType.GRANT)
191
     @Log(title = "角色管理", businessType = BusinessType.GRANT)
192
     @PutMapping("/authUser/cancel")
192
     @PutMapping("/authUser/cancel")
193
     public AjaxResult cancelAuthUser(@RequestBody SysUserRole userRole)
193
     public AjaxResult cancelAuthUser(@RequestBody SysUserRole userRole)
@@ -198,7 +198,7 @@ public class SysRoleController extends BaseController
198
     /**
198
     /**
199
      * 批量取消授权用户
199
      * 批量取消授权用户
200
      */
200
      */
201
-    @PreAuthorize(hasPermi = "system:role:edit")
201
+    @RequiresPermissions("system:role:edit")
202
     @Log(title = "角色管理", businessType = BusinessType.GRANT)
202
     @Log(title = "角色管理", businessType = BusinessType.GRANT)
203
     @PutMapping("/authUser/cancelAll")
203
     @PutMapping("/authUser/cancelAll")
204
     public AjaxResult cancelAuthUserAll(Long roleId, Long[] userIds)
204
     public AjaxResult cancelAuthUserAll(Long roleId, Long[] userIds)
@@ -209,7 +209,7 @@ public class SysRoleController extends BaseController
209
     /**
209
     /**
210
      * 批量选择用户授权
210
      * 批量选择用户授权
211
      */
211
      */
212
-    @PreAuthorize(hasPermi = "system:role:edit")
212
+    @RequiresPermissions("system:role:edit")
213
     @Log(title = "角色管理", businessType = BusinessType.GRANT)
213
     @Log(title = "角色管理", businessType = BusinessType.GRANT)
214
     @PutMapping("/authUser/selectAll")
214
     @PutMapping("/authUser/selectAll")
215
     public AjaxResult selectAuthUserAll(Long roleId, Long[] userIds)
215
     public AjaxResult selectAuthUserAll(Long roleId, Long[] userIds)

+ 12 - 12
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java

@@ -28,7 +28,7 @@ import com.ruoyi.common.core.web.page.TableDataInfo;
28
 import com.ruoyi.common.log.annotation.Log;
28
 import com.ruoyi.common.log.annotation.Log;
29
 import com.ruoyi.common.log.enums.BusinessType;
29
 import com.ruoyi.common.log.enums.BusinessType;
30
 import com.ruoyi.common.security.annotation.InnerAuth;
30
 import com.ruoyi.common.security.annotation.InnerAuth;
31
-import com.ruoyi.common.security.annotation.PreAuthorize;
31
+import com.ruoyi.common.security.annotation.RequiresPermissions;
32
 import com.ruoyi.system.api.domain.SysRole;
32
 import com.ruoyi.system.api.domain.SysRole;
33
 import com.ruoyi.system.api.domain.SysUser;
33
 import com.ruoyi.system.api.domain.SysUser;
34
 import com.ruoyi.system.api.model.LoginUser;
34
 import com.ruoyi.system.api.model.LoginUser;
@@ -65,7 +65,7 @@ public class SysUserController extends BaseController
65
     /**
65
     /**
66
      * 获取用户列表
66
      * 获取用户列表
67
      */
67
      */
68
-    @PreAuthorize(hasPermi = "system:user:list")
68
+    @RequiresPermissions("system:user:list")
69
     @GetMapping("/list")
69
     @GetMapping("/list")
70
     public TableDataInfo list(SysUser user)
70
     public TableDataInfo list(SysUser user)
71
     {
71
     {
@@ -75,7 +75,7 @@ public class SysUserController extends BaseController
75
     }
75
     }
76
 
76
 
77
     @Log(title = "用户管理", businessType = BusinessType.EXPORT)
77
     @Log(title = "用户管理", businessType = BusinessType.EXPORT)
78
-    @PreAuthorize(hasPermi = "system:user:export")
78
+    @RequiresPermissions("system:user:export")
79
     @PostMapping("/export")
79
     @PostMapping("/export")
80
     public void export(HttpServletResponse response, SysUser user) throws IOException
80
     public void export(HttpServletResponse response, SysUser user) throws IOException
81
     {
81
     {
@@ -85,7 +85,7 @@ public class SysUserController extends BaseController
85
     }
85
     }
86
 
86
 
87
     @Log(title = "用户管理", businessType = BusinessType.IMPORT)
87
     @Log(title = "用户管理", businessType = BusinessType.IMPORT)
88
-    @PreAuthorize(hasPermi = "system:user:import")
88
+    @RequiresPermissions("system:user:import")
89
     @PostMapping("/importData")
89
     @PostMapping("/importData")
90
     public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception
90
     public AjaxResult importData(MultipartFile file, boolean updateSupport) throws Exception
91
     {
91
     {
@@ -168,7 +168,7 @@ public class SysUserController extends BaseController
168
     /**
168
     /**
169
      * 根据用户编号获取详细信息
169
      * 根据用户编号获取详细信息
170
      */
170
      */
171
-    @PreAuthorize(hasPermi = "system:user:query")
171
+    @RequiresPermissions("system:user:query")
172
     @GetMapping(value = { "/", "/{userId}" })
172
     @GetMapping(value = { "/", "/{userId}" })
173
     public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId)
173
     public AjaxResult getInfo(@PathVariable(value = "userId", required = false) Long userId)
174
     {
174
     {
@@ -189,7 +189,7 @@ public class SysUserController extends BaseController
189
     /**
189
     /**
190
      * 新增用户
190
      * 新增用户
191
      */
191
      */
192
-    @PreAuthorize(hasPermi = "system:user:add")
192
+    @RequiresPermissions("system:user:add")
193
     @Log(title = "用户管理", businessType = BusinessType.INSERT)
193
     @Log(title = "用户管理", businessType = BusinessType.INSERT)
194
     @PostMapping
194
     @PostMapping
195
     public AjaxResult add(@Validated @RequestBody SysUser user)
195
     public AjaxResult add(@Validated @RequestBody SysUser user)
@@ -216,7 +216,7 @@ public class SysUserController extends BaseController
216
     /**
216
     /**
217
      * 修改用户
217
      * 修改用户
218
      */
218
      */
219
-    @PreAuthorize(hasPermi = "system:user:edit")
219
+    @RequiresPermissions("system:user:edit")
220
     @Log(title = "用户管理", businessType = BusinessType.UPDATE)
220
     @Log(title = "用户管理", businessType = BusinessType.UPDATE)
221
     @PutMapping
221
     @PutMapping
222
     public AjaxResult edit(@Validated @RequestBody SysUser user)
222
     public AjaxResult edit(@Validated @RequestBody SysUser user)
@@ -239,7 +239,7 @@ public class SysUserController extends BaseController
239
     /**
239
     /**
240
      * 删除用户
240
      * 删除用户
241
      */
241
      */
242
-    @PreAuthorize(hasPermi = "system:user:remove")
242
+    @RequiresPermissions("system:user:remove")
243
     @Log(title = "用户管理", businessType = BusinessType.DELETE)
243
     @Log(title = "用户管理", businessType = BusinessType.DELETE)
244
     @DeleteMapping("/{userIds}")
244
     @DeleteMapping("/{userIds}")
245
     public AjaxResult remove(@PathVariable Long[] userIds)
245
     public AjaxResult remove(@PathVariable Long[] userIds)
@@ -254,7 +254,7 @@ public class SysUserController extends BaseController
254
     /**
254
     /**
255
      * 重置密码
255
      * 重置密码
256
      */
256
      */
257
-    @PreAuthorize(hasPermi = "system:user:edit")
257
+    @RequiresPermissions("system:user:edit")
258
     @Log(title = "用户管理", businessType = BusinessType.UPDATE)
258
     @Log(title = "用户管理", businessType = BusinessType.UPDATE)
259
     @PutMapping("/resetPwd")
259
     @PutMapping("/resetPwd")
260
     public AjaxResult resetPwd(@RequestBody SysUser user)
260
     public AjaxResult resetPwd(@RequestBody SysUser user)
@@ -268,7 +268,7 @@ public class SysUserController extends BaseController
268
     /**
268
     /**
269
      * 状态修改
269
      * 状态修改
270
      */
270
      */
271
-    @PreAuthorize(hasPermi = "system:user:edit")
271
+    @RequiresPermissions("system:user:edit")
272
     @Log(title = "用户管理", businessType = BusinessType.UPDATE)
272
     @Log(title = "用户管理", businessType = BusinessType.UPDATE)
273
     @PutMapping("/changeStatus")
273
     @PutMapping("/changeStatus")
274
     public AjaxResult changeStatus(@RequestBody SysUser user)
274
     public AjaxResult changeStatus(@RequestBody SysUser user)
@@ -281,7 +281,7 @@ public class SysUserController extends BaseController
281
     /**
281
     /**
282
      * 根据用户编号获取授权角色
282
      * 根据用户编号获取授权角色
283
      */
283
      */
284
-    @PreAuthorize(hasPermi = "system:user:query")
284
+    @RequiresPermissions("system:user:query")
285
     @GetMapping("/authRole/{userId}")
285
     @GetMapping("/authRole/{userId}")
286
     public AjaxResult authRole(@PathVariable("userId") Long userId)
286
     public AjaxResult authRole(@PathVariable("userId") Long userId)
287
     {
287
     {
@@ -296,7 +296,7 @@ public class SysUserController extends BaseController
296
     /**
296
     /**
297
      * 用户授权角色
297
      * 用户授权角色
298
      */
298
      */
299
-    @PreAuthorize(hasPermi = "system:user:edit")
299
+    @RequiresPermissions("system:user:edit")
300
     @Log(title = "用户管理", businessType = BusinessType.GRANT)
300
     @Log(title = "用户管理", businessType = BusinessType.GRANT)
301
     @PutMapping("/authRole")
301
     @PutMapping("/authRole")
302
     public AjaxResult insertAuthRole(Long userId, Long[] roleIds)
302
     public AjaxResult insertAuthRole(Long userId, Long[] roleIds)

+ 3 - 3
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserOnlineController.java

@@ -18,7 +18,7 @@ import com.ruoyi.common.core.web.page.TableDataInfo;
18
 import com.ruoyi.common.log.annotation.Log;
18
 import com.ruoyi.common.log.annotation.Log;
19
 import com.ruoyi.common.log.enums.BusinessType;
19
 import com.ruoyi.common.log.enums.BusinessType;
20
 import com.ruoyi.common.redis.service.RedisService;
20
 import com.ruoyi.common.redis.service.RedisService;
21
-import com.ruoyi.common.security.annotation.PreAuthorize;
21
+import com.ruoyi.common.security.annotation.RequiresPermissions;
22
 import com.ruoyi.system.api.model.LoginUser;
22
 import com.ruoyi.system.api.model.LoginUser;
23
 import com.ruoyi.system.domain.SysUserOnline;
23
 import com.ruoyi.system.domain.SysUserOnline;
24
 import com.ruoyi.system.service.ISysUserOnlineService;
24
 import com.ruoyi.system.service.ISysUserOnlineService;
@@ -38,7 +38,7 @@ public class SysUserOnlineController extends BaseController
38
     @Autowired
38
     @Autowired
39
     private RedisService redisService;
39
     private RedisService redisService;
40
 
40
 
41
-    @PreAuthorize(hasPermi = "monitor:online:list")
41
+    @RequiresPermissions("monitor:online:list")
42
     @GetMapping("/list")
42
     @GetMapping("/list")
43
     public TableDataInfo list(String ipaddr, String userName)
43
     public TableDataInfo list(String ipaddr, String userName)
44
     {
44
     {
@@ -81,7 +81,7 @@ public class SysUserOnlineController extends BaseController
81
     /**
81
     /**
82
      * 强退用户
82
      * 强退用户
83
      */
83
      */
84
-    @PreAuthorize(hasPermi = "monitor:online:forceLogout")
84
+    @RequiresPermissions("monitor:online:forceLogout")
85
     @Log(title = "在线用户", businessType = BusinessType.FORCE)
85
     @Log(title = "在线用户", businessType = BusinessType.FORCE)
86
     @DeleteMapping("/{tokenId}")
86
     @DeleteMapping("/{tokenId}")
87
     public AjaxResult forceLogout(@PathVariable String tokenId)
87
     public AjaxResult forceLogout(@PathVariable String tokenId)