BoundSql没有getConfiguration(),是版本问题吗?
我想要在mybatisPlus的拦截器中对insert,update方法进行拦截,实现对要插入的数据进行长度校验。
还有其他办法可以获取connection吗
版本:
//基于MyBatis,你可以使用拦截器(Interceptor)来实现通用的数据长度校验。以下是一个示例拦截器的实现:
// 1. 自定义拦截器类,并实现Interceptor接口。在intercept方法中,读取数据库中每个字段的最大长度限制,然后对要插入的数据进行校验并截取。
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.util.Properties;
import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.executor.statement.StatementHandler;
import org.apache.ibatis.mapping.BoundSql;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.plugin.*;
import javax.security.auth.login.Configuration;
@Intercepts({
@Signature(type = StatementHandler.class, method = "update", args = {java.sql.Statement.class})
})
public class DataLengthInterceptor implements Interceptor {
@Override
public Object intercept(Invocation invocation) throws Throwable {
System.out.println("==================================hyg==========================================");
StatementHandler statementHandler = (StatementHandler) invocation.getTarget();
Connection connection = statementHandler.getBoundSql().getConfiguration().getEnvironment().getDataSource().getConnection();
try {
// 获取数据库中每个字段的最大长度限制
DatabaseMetaData meta = connection.getMetaData();
ResultSet resultSet = meta.getColumns(null, null, null, null);
while (resultSet.next()) {
String tableName = resultSet.getString("TABLE_NAME");
String columnName = resultSet.getString("COLUMN_NAME");
int maxLength = resultSet.getInt("COLUMN_SIZE");
// 对要插入的数据进行校验并截取
String sql = statementHandler.getBoundSql().getSql();
if (sql.toLowerCase().contains(tableName.toLowerCase())
&& sql.toLowerCase().contains(columnName.toLowerCase())) {
Object parameterObject = statementHandler.getBoundSql().getParameterObject();
if (parameterObject instanceof String) {
String value = (String) parameterObject;
String truncatedValue = StringUtils.truncate(value, maxLength);
statementHandler.getBoundSql().setAdditionalParameter(columnName, truncatedValue);
}
}
}
} finally {
connection.close();
}
return invocation.proceed();
}
@Override
public Object plugin(Object target) {
return Plugin.wrap(target, this);
}
@Override
public void setProperties(Properties properties) {
// You can provide some properties here if needed
}
}
各位有什么解决办法吗?