mirror of
				https://github.com/continew-org/continew-admin.git
				synced 2025-10-31 22:57:17 +08:00 
			
		
		
		
	refactor: 升级 MyBatis Plus 3.5.3.1 => 3.5.3.2,并优化数据权限处理
1.解决升级到 MyBatis Plus 3.5.3.2 后,由于 BaseMapper 接口变化导致部分数据权限处理报 Invalid bound statement (not found) 错误的问题(处理思路来源于:https://github.com/baomidou/mybatis-plus/issues/5630) 2.提取 DataPermissionMapper(数据权限 Mapper 基类),如需处理通用 Mapper 方法的数据权限,继承该 Mapper 即可
This commit is contained in:
		| @@ -275,8 +275,8 @@ continew-admin | |||||||
|  |  | ||||||
| ## 核心技术栈 | ## 核心技术栈 | ||||||
|  |  | ||||||
| | 名称                                                         | 版本           | 简介                                                         | | | 名称                                                         | 版本         | 简介                                                         | | ||||||
| | :----------------------------------------------------------- |:-------------| :----------------------------------------------------------- | | | :----------------------------------------------------------- | :----------- | :----------------------------------------------------------- | | ||||||
| | <a href="https://cn.vuejs.org/" target="_blank">Vue</a>      | 3.3.4        | 渐进式 JavaScript 框架,易学易用,性能出色,适用场景丰富的 Web 前端框架。 | | | <a href="https://cn.vuejs.org/" target="_blank">Vue</a>      | 3.3.4        | 渐进式 JavaScript 框架,易学易用,性能出色,适用场景丰富的 Web 前端框架。 | | ||||||
| | <a href="https://www.typescriptlang.org/zh/" target="_blank">TypeScript</a> | 4.9.5        | TypeScript 是微软开发的一个开源的编程语言,通过在 JavaScript 的基础上添加静态类型定义构建而成。 | | | <a href="https://www.typescriptlang.org/zh/" target="_blank">TypeScript</a> | 4.9.5        | TypeScript 是微软开发的一个开源的编程语言,通过在 JavaScript 的基础上添加静态类型定义构建而成。 | | ||||||
| | <a href="https://arco.design/vue/docs/start" target="_blank">Arco Design Vue</a> | 2.51.0       | 字节跳动推出的前端 UI 框架,样式美观,组件丰富。             | | | <a href="https://arco.design/vue/docs/start" target="_blank">Arco Design Vue</a> | 2.51.0       | 字节跳动推出的前端 UI 框架,样式美观,组件丰富。             | | ||||||
| @@ -284,7 +284,7 @@ continew-admin | |||||||
| | <a href="https://undertow.io/" target="_blank">Undertow</a>  | 2.2.26.Final | 采用 Java 开发的灵活的高性能 Web 服务器,提供包括阻塞和基于 NIO 的非堵塞机制。 | | | <a href="https://undertow.io/" target="_blank">Undertow</a>  | 2.2.26.Final | 采用 Java 开发的灵活的高性能 Web 服务器,提供包括阻塞和基于 NIO 的非堵塞机制。 | | ||||||
| | <a href="https://sa-token.dev33.cn/" target="_blank">Sa-Token + JWT</a> | 1.35.0.RC    | 轻量级 Java 权限认证框架,让鉴权变得简单、优雅。             | | | <a href="https://sa-token.dev33.cn/" target="_blank">Sa-Token + JWT</a> | 1.35.0.RC    | 轻量级 Java 权限认证框架,让鉴权变得简单、优雅。             | | ||||||
| | <a href="https://mariadb.org/" target="_blank">MariaDB</a>   | 10.10.2      | MySQL 的一个分支,主要由开源社区在维护,完全兼容 MySQL,包括 API 和命令行,能轻松成为 MySQL 的代替品。 | | | <a href="https://mariadb.org/" target="_blank">MariaDB</a>   | 10.10.2      | MySQL 的一个分支,主要由开源社区在维护,完全兼容 MySQL,包括 API 和命令行,能轻松成为 MySQL 的代替品。 | | ||||||
| | <a href="https://baomidou.com/" target="_blank">MyBatis Plus</a> | 3.5.3.1      | MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,简化开发、提高效率。 | | | <a href="https://baomidou.com/" target="_blank">MyBatis Plus</a> | 3.5.3.2      | MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,简化开发、提高效率。 | | ||||||
| | <a href="https://www.kancloud.cn/tracy5546/dynamic-datasource/2264611" target="_blank">dynamic-datasource-spring-boot-starter</a> | 3.6.1        | 基于 Spring Boot 的快速集成多数据源的启动器。                | | | <a href="https://www.kancloud.cn/tracy5546/dynamic-datasource/2264611" target="_blank">dynamic-datasource-spring-boot-starter</a> | 3.6.1        | 基于 Spring Boot 的快速集成多数据源的启动器。                | | ||||||
| | Hikari                                                       | 4.0.3        | JDBC 连接池,号称 “史上最快连接池”,SpringBoot 在 2.0 之后,采用的默认数据库连接池就是 Hikari。 | | | Hikari                                                       | 4.0.3        | JDBC 连接池,号称 “史上最快连接池”,SpringBoot 在 2.0 之后,采用的默认数据库连接池就是 Hikari。 | | ||||||
| | <a href="https://dev.mysql.com/doc/connector-j/8.0/en/" target="_blank">mysql-connector-j</a> | 8.0.33       | MySQL Java 驱动。                                            | | | <a href="https://dev.mysql.com/doc/connector-j/8.0/en/" target="_blank">mysql-connector-j</a> | 8.0.33       | MySQL Java 驱动。                                            | | ||||||
|   | |||||||
| @@ -0,0 +1,46 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2022-present Charles7c Authors. All Rights Reserved. | ||||||
|  |  * | ||||||
|  |  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  |  * you may not use this file except in compliance with the License. | ||||||
|  |  * You may obtain a copy of the License at | ||||||
|  |  * | ||||||
|  |  *     http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  |  * | ||||||
|  |  * Unless required by applicable law or agreed to in writing, software | ||||||
|  |  * distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  |  * See the License for the specific language governing permissions and | ||||||
|  |  * limitations under the License. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package top.charles7c.cnadmin.common.base; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | import org.apache.ibatis.annotations.Param; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.Wrapper; | ||||||
|  | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
|  | import com.baomidou.mybatisplus.core.toolkit.Constants; | ||||||
|  |  | ||||||
|  | import top.charles7c.cnadmin.common.annotation.DataPermission; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 数据权限 Mapper 基类 | ||||||
|  |  * | ||||||
|  |  * @param <T> | ||||||
|  |  *            实体类 | ||||||
|  |  * @author Charles7c | ||||||
|  |  * @since 2023/9/3 21:50 | ||||||
|  |  */ | ||||||
|  | public interface DataPermissionMapper<T> extends BaseMapper<T> { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     @DataPermission | ||||||
|  |     List<T> selectList(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     @DataPermission | ||||||
|  |     List<T> selectList(IPage<T> page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper); | ||||||
|  | } | ||||||
| @@ -77,12 +77,11 @@ public class DataPermissionHandlerImpl implements DataPermissionHandler { | |||||||
|             Class<?> clazz = |             Class<?> clazz = | ||||||
|                 Class.forName(mappedStatementId.substring(0, mappedStatementId.lastIndexOf(StringConsts.DOT))); |                 Class.forName(mappedStatementId.substring(0, mappedStatementId.lastIndexOf(StringConsts.DOT))); | ||||||
|             String methodName = mappedStatementId.substring(mappedStatementId.lastIndexOf(StringConsts.DOT) + 1); |             String methodName = mappedStatementId.substring(mappedStatementId.lastIndexOf(StringConsts.DOT) + 1); | ||||||
|             Method[] methods = clazz.getDeclaredMethods(); |             Method[] methodArr = clazz.getMethods(); | ||||||
|             for (Method method : methods) { |             for (Method method : methodArr) { | ||||||
|                 DataPermission dataPermission = method.getAnnotation(DataPermission.class); |                 DataPermission dataPermission = method.getAnnotation(DataPermission.class); | ||||||
|                 if (null != dataPermission |                 if (null != dataPermission | ||||||
|                     && (method.getName().equals(methodName) || (method.getName() + "_COUNT").equals(methodName))) { |                     && (method.getName().equals(methodName) || (method.getName() + "_COUNT").equals(methodName))) { | ||||||
|                     // 获取当前登录用户 |  | ||||||
|                     LoginUser loginUser = LoginHelper.getLoginUser(); |                     LoginUser loginUser = LoginHelper.getLoginUser(); | ||||||
|                     if (null != loginUser && !loginUser.isAdmin()) { |                     if (null != loginUser && !loginUser.isAdmin()) { | ||||||
|                         return buildDataScopeFilter(loginUser, dataPermission.value(), where); |                         return buildDataScopeFilter(loginUser, dataPermission.value(), where); | ||||||
| @@ -106,7 +105,7 @@ public class DataPermissionHandlerImpl implements DataPermissionHandler { | |||||||
|      *            当前查询条件 |      *            当前查询条件 | ||||||
|      * @return 构建后查询条件 |      * @return 构建后查询条件 | ||||||
|      */ |      */ | ||||||
|     private static Expression buildDataScopeFilter(LoginUser user, String tableAlias, Expression where) { |     private Expression buildDataScopeFilter(LoginUser user, String tableAlias, Expression where) { | ||||||
|         Expression expression = null; |         Expression expression = null; | ||||||
|         for (RoleDTO role : user.getRoles()) { |         for (RoleDTO role : user.getRoles()) { | ||||||
|             DataScopeEnum dataScope = role.getDataScope(); |             DataScopeEnum dataScope = role.getDataScope(); | ||||||
| @@ -131,19 +130,19 @@ public class DataPermissionHandlerImpl implements DataPermissionHandler { | |||||||
|                 subSelect.setSelectBody(select); |                 subSelect.setSelectBody(select); | ||||||
|                 // 构建父查询 |                 // 构建父查询 | ||||||
|                 InExpression inExpression = new InExpression(); |                 InExpression inExpression = new InExpression(); | ||||||
|                 inExpression.setLeftExpression(buildColumn(tableAlias, DEPT_ID)); |                 inExpression.setLeftExpression(this.buildColumn(tableAlias, DEPT_ID)); | ||||||
|                 inExpression.setRightExpression(subSelect); |                 inExpression.setRightExpression(subSelect); | ||||||
|                 expression = null != expression ? new OrExpression(expression, inExpression) : inExpression; |                 expression = null != expression ? new OrExpression(expression, inExpression) : inExpression; | ||||||
|             } else if (DataScopeEnum.DEPT.equals(dataScope)) { |             } else if (DataScopeEnum.DEPT.equals(dataScope)) { | ||||||
|                 // select t1.* from table as t1 where t1.`dept_id` = xxx; |                 // select t1.* from table as t1 where t1.`dept_id` = xxx; | ||||||
|                 EqualsTo equalsTo = new EqualsTo(); |                 EqualsTo equalsTo = new EqualsTo(); | ||||||
|                 equalsTo.setLeftExpression(buildColumn(tableAlias, DEPT_ID)); |                 equalsTo.setLeftExpression(this.buildColumn(tableAlias, DEPT_ID)); | ||||||
|                 equalsTo.setRightExpression(new LongValue(user.getDeptId())); |                 equalsTo.setRightExpression(new LongValue(user.getDeptId())); | ||||||
|                 expression = null != expression ? new OrExpression(expression, equalsTo) : equalsTo; |                 expression = null != expression ? new OrExpression(expression, equalsTo) : equalsTo; | ||||||
|             } else if (DataScopeEnum.SELF.equals(dataScope)) { |             } else if (DataScopeEnum.SELF.equals(dataScope)) { | ||||||
|                 // select t1.* from table as t1 where t1.`create_user` = xxx; |                 // select t1.* from table as t1 where t1.`create_user` = xxx; | ||||||
|                 EqualsTo equalsTo = new EqualsTo(); |                 EqualsTo equalsTo = new EqualsTo(); | ||||||
|                 equalsTo.setLeftExpression(buildColumn(tableAlias, CREATE_USER)); |                 equalsTo.setLeftExpression(this.buildColumn(tableAlias, CREATE_USER)); | ||||||
|                 equalsTo.setRightExpression(new LongValue(user.getId())); |                 equalsTo.setRightExpression(new LongValue(user.getId())); | ||||||
|                 expression = null != expression ? new OrExpression(expression, equalsTo) : equalsTo; |                 expression = null != expression ? new OrExpression(expression, equalsTo) : equalsTo; | ||||||
|             } else if (DataScopeEnum.CUSTOM.equals(dataScope)) { |             } else if (DataScopeEnum.CUSTOM.equals(dataScope)) { | ||||||
| @@ -161,7 +160,7 @@ public class DataPermissionHandlerImpl implements DataPermissionHandler { | |||||||
|                 subSelect.setSelectBody(select); |                 subSelect.setSelectBody(select); | ||||||
|                 // 构建父查询 |                 // 构建父查询 | ||||||
|                 InExpression inExpression = new InExpression(); |                 InExpression inExpression = new InExpression(); | ||||||
|                 inExpression.setLeftExpression(buildColumn(tableAlias, DEPT_ID)); |                 inExpression.setLeftExpression(this.buildColumn(tableAlias, DEPT_ID)); | ||||||
|                 inExpression.setRightExpression(subSelect); |                 inExpression.setRightExpression(subSelect); | ||||||
|                 expression = null != expression ? new OrExpression(expression, inExpression) : inExpression; |                 expression = null != expression ? new OrExpression(expression, inExpression) : inExpression; | ||||||
|             } |             } | ||||||
| @@ -178,7 +177,7 @@ public class DataPermissionHandlerImpl implements DataPermissionHandler { | |||||||
|      *            字段名称 |      *            字段名称 | ||||||
|      * @return 带表别名字段 |      * @return 带表别名字段 | ||||||
|      */ |      */ | ||||||
|     private static Column buildColumn(String tableAlias, String columnName) { |     private Column buildColumn(String tableAlias, String columnName) { | ||||||
|         if (StringUtils.isNotEmpty(tableAlias)) { |         if (StringUtils.isNotEmpty(tableAlias)) { | ||||||
|             columnName = String.format("%s.%s", tableAlias, columnName); |             columnName = String.format("%s.%s", tableAlias, columnName); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -16,17 +16,10 @@ | |||||||
|  |  | ||||||
| package top.charles7c.cnadmin.system.mapper; | package top.charles7c.cnadmin.system.mapper; | ||||||
|  |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| import org.apache.ibatis.annotations.Param; | import org.apache.ibatis.annotations.Param; | ||||||
| import org.apache.ibatis.annotations.Select; | import org.apache.ibatis.annotations.Select; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.Wrapper; | import top.charles7c.cnadmin.common.base.DataPermissionMapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Constants; |  | ||||||
|  |  | ||||||
| import top.charles7c.cnadmin.common.annotation.DataPermission; |  | ||||||
| import top.charles7c.cnadmin.common.base.BaseMapper; |  | ||||||
| import top.charles7c.cnadmin.system.model.entity.UserDO; | import top.charles7c.cnadmin.system.model.entity.UserDO; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -35,15 +28,7 @@ import top.charles7c.cnadmin.system.model.entity.UserDO; | |||||||
|  * @author Charles7c |  * @author Charles7c | ||||||
|  * @since 2022/12/22 21:47 |  * @since 2022/12/22 21:47 | ||||||
|  */ |  */ | ||||||
| public interface UserMapper extends BaseMapper<UserDO> { | public interface UserMapper extends DataPermissionMapper<UserDO> { | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     @DataPermission |  | ||||||
|     List<UserDO> selectList(@Param(Constants.WRAPPER) Wrapper<UserDO> queryWrapper); |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     @DataPermission |  | ||||||
|     <P extends IPage<UserDO>> P selectPage(P page, @Param(Constants.WRAPPER) Wrapper<UserDO> queryWrapper); |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 根据用户名查询 |      * 根据用户名查询 | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								pom.xml
									
									
									
									
									
								
							| @@ -47,7 +47,7 @@ limitations under the License. | |||||||
|         <sa-token.version>1.35.0.RC</sa-token.version> |         <sa-token.version>1.35.0.RC</sa-token.version> | ||||||
|  |  | ||||||
|         <!-- ### 持久层相关 ### --> |         <!-- ### 持久层相关 ### --> | ||||||
|         <mybatis-plus.version>3.5.3.1</mybatis-plus.version> |         <mybatis-plus.version>3.5.3.2</mybatis-plus.version> | ||||||
|         <dynamic-ds.version>3.6.1</dynamic-ds.version> |         <dynamic-ds.version>3.6.1</dynamic-ds.version> | ||||||
|         <p6spy.version>3.9.1</p6spy.version> |         <p6spy.version>3.9.1</p6spy.version> | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user