潘志宝
2024-11-12 1337f249608bcbd7ad6cf244870e560a95821727
提交 | 用户 | 时间
a6de49 1 /**
H 2  * Copyright (c) 2018 人人开源 All rights reserved.
3  *
4  * https://www.renren.io
5  *
6  * 版权所有,侵权必究!
7  */
8
9 package com.iailab.framework.mybatis.interceptor;
10
11 import cn.hutool.core.util.StrUtil;
12 import com.baomidou.mybatisplus.core.toolkit.PluginUtils;
13 import com.baomidou.mybatisplus.extension.plugins.inner.InnerInterceptor;
14 import net.sf.jsqlparser.JSQLParserException;
15 import net.sf.jsqlparser.expression.Expression;
16 import net.sf.jsqlparser.expression.StringValue;
17 import net.sf.jsqlparser.expression.operators.conditional.AndExpression;
18 import net.sf.jsqlparser.parser.CCJSqlParserUtil;
19 import net.sf.jsqlparser.statement.select.PlainSelect;
20 import net.sf.jsqlparser.statement.select.Select;
21 import org.apache.ibatis.executor.Executor;
22 import org.apache.ibatis.mapping.BoundSql;
23 import org.apache.ibatis.mapping.MappedStatement;
24 import org.apache.ibatis.session.ResultHandler;
25 import org.apache.ibatis.session.RowBounds;
26
27 import java.util.Map;
28
29 /**
30  * 数据过滤
31  *
32  * @author Mark sunlightcs@gmail.com
33  */
34 public class DataFilterInterceptor implements InnerInterceptor {
35
36     @Override
37     public void beforeQuery(Executor executor, MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {
38         DataScope scope = getDataScope(parameter);
39         // 不进行数据过滤
40         if(scope == null || StrUtil.isBlank(scope.getSqlFilter())){
41             return;
42         }
43
44         // 拼接新SQL
45         String buildSql = getSelect(boundSql.getSql(), scope);
46
47         // 重写SQL
48         PluginUtils.mpBoundSql(boundSql).sql(buildSql);
49     }
50
51     private DataScope getDataScope(Object parameter){
52         if (parameter == null){
53             return null;
54         }
55
56         // 判断参数里是否有DataScope对象
57         if (parameter instanceof Map) {
58             Map<?, ?> parameterMap = (Map<?, ?>) parameter;
59             for (Map.Entry entry : parameterMap.entrySet()) {
60                 if (entry.getValue() != null && entry.getValue() instanceof DataScope) {
61                     return (DataScope) entry.getValue();
62                 }
63             }
64         } else if (parameter instanceof DataScope) {
65             return (DataScope) parameter;
66         }
67
68         return null;
69     }
70
71     private String getSelect(String buildSql, DataScope scope){
72         try {
73             Select select = (Select) CCJSqlParserUtil.parse(buildSql);
74             PlainSelect plainSelect = (PlainSelect) select.getSelectBody();
75
76             Expression expression = plainSelect.getWhere();
77             if(expression == null){
78                 plainSelect.setWhere(new StringValue(scope.getSqlFilter()));
79             }else{
80                 AndExpression andExpression =  new AndExpression(expression, new StringValue(scope.getSqlFilter()));
81                 plainSelect.setWhere(andExpression);
82             }
83
84             return select.toString().replaceAll("'", "");
85         }catch (JSQLParserException e){
86             return buildSql;
87         }
88     }
89 }