优化数据权限
This commit is contained in:
parent
20bcefc5f4
commit
9da2bd8524
|
@ -5,7 +5,6 @@ import com.baomidou.mybatisplus.core.toolkit.PluginUtils;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.inner.InnerInterceptor;
|
import com.baomidou.mybatisplus.extension.plugins.inner.InnerInterceptor;
|
||||||
import net.sf.jsqlparser.JSQLParserException;
|
import net.sf.jsqlparser.JSQLParserException;
|
||||||
import net.sf.jsqlparser.expression.Expression;
|
import net.sf.jsqlparser.expression.Expression;
|
||||||
import net.sf.jsqlparser.expression.StringValue;
|
|
||||||
import net.sf.jsqlparser.expression.operators.conditional.AndExpression;
|
import net.sf.jsqlparser.expression.operators.conditional.AndExpression;
|
||||||
import net.sf.jsqlparser.parser.CCJSqlParserUtil;
|
import net.sf.jsqlparser.parser.CCJSqlParserUtil;
|
||||||
import net.sf.jsqlparser.statement.select.PlainSelect;
|
import net.sf.jsqlparser.statement.select.PlainSelect;
|
||||||
|
@ -73,7 +72,7 @@ public class DataScopeInnerInterceptor implements InnerInterceptor {
|
||||||
plainSelect.setWhere(andExpression);
|
plainSelect.setWhere(andExpression);
|
||||||
}
|
}
|
||||||
|
|
||||||
return select.toString().replaceAll("'", "");
|
return select.toString();
|
||||||
} catch (JSQLParserException e) {
|
} catch (JSQLParserException e) {
|
||||||
return buildSql;
|
return buildSql;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,108 @@
|
||||||
|
package net.maku.framework.mybatis.interceptor;
|
||||||
|
|
||||||
|
import net.sf.jsqlparser.expression.Expression;
|
||||||
|
import net.sf.jsqlparser.expression.ExpressionVisitor;
|
||||||
|
import net.sf.jsqlparser.parser.ASTNodeAccessImpl;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
public class StringValue extends ASTNodeAccessImpl implements Expression {
|
||||||
|
|
||||||
|
private String value = "";
|
||||||
|
private String prefix = null;
|
||||||
|
|
||||||
|
public static final List<String> ALLOWED_PREFIXES = Arrays.asList("N", "U", "E", "R", "B", "RB", "_utf8");
|
||||||
|
|
||||||
|
public StringValue() {
|
||||||
|
// empty constructor
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringValue(String escapedValue) {
|
||||||
|
// removing "'" at the start and at the end
|
||||||
|
if (escapedValue.startsWith("'") && escapedValue.endsWith("'")) {
|
||||||
|
value = escapedValue.substring(1, escapedValue.length() - 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (escapedValue.length() > 2) {
|
||||||
|
for (String p : ALLOWED_PREFIXES) {
|
||||||
|
if (escapedValue.length() > p.length() && escapedValue.substring(0, p.length()).equalsIgnoreCase(p)
|
||||||
|
&& escapedValue.charAt(p.length()) == '\'') {
|
||||||
|
this.prefix = p;
|
||||||
|
value = escapedValue.substring(p.length() + 1, escapedValue.length() - 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
value = escapedValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getValue() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPrefix() {
|
||||||
|
return prefix;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNotExcapedValue() {
|
||||||
|
StringBuilder buffer = new StringBuilder(value);
|
||||||
|
int index = 0;
|
||||||
|
int deletesNum = 0;
|
||||||
|
while ((index = value.indexOf("''", index)) != -1) {
|
||||||
|
buffer.deleteCharAt(index - deletesNum);
|
||||||
|
index += 2;
|
||||||
|
deletesNum++;
|
||||||
|
}
|
||||||
|
return buffer.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setValue(String string) {
|
||||||
|
value = string;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPrefix(String prefix) {
|
||||||
|
this.prefix = prefix;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void accept(ExpressionVisitor expressionVisitor) {
|
||||||
|
// expressionVisitor.visit(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return (prefix != null ? prefix : "") + value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringValue withPrefix(String prefix) {
|
||||||
|
this.setPrefix(prefix);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringValue withValue(String value) {
|
||||||
|
this.setValue(value);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (o == null || getClass() != o.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
StringValue that = (StringValue) o;
|
||||||
|
return Objects.equals(value, that.value) && Objects.equals(prefix, that.prefix);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(value, prefix);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user