java自定义sql占位符替换工具
PlaceholderParse
public class PlaceholderParse {
private static final String SQL_INJECT_CHARS;
private PlaceholderParse() {
}
static {
SQL_INJECT_CHARS = "([';]+|(--)+|(\\\\s+([aA][nN][dD])\\\\s+)+|(\\\\s+([oO][rR])\\\\s+)+)";
}
public static String parse(String openToken, String closeToken, String text, Object... args) {
if (args == null || args.length <= 0) {
return text;
}
int argsIndex = 0;
if (text == null || text.isEmpty()) {
return "";
}
char[] src = text.toCharArray();
int offset = 0;
int start = text.indexOf(openToken, offset);
if (start == -1) {
return text;
}
final StringBuilder builder = new StringBuilder();
StringBuilder expression = null;
while (start > -1) {
if (start > 0 && src[start - 1] == '\\') {
builder.append(src, offset, start - offset - 1).append(openToken);
offset = start + openToken.length();
} else {
if (expression == null) {
expression = new StringBuilder();
} else {
expression.setLength(0);
}
builder.append(src, offset, start - offset);
offset = start + openToken.length();
int end = text.indexOf(closeToken, offset);
while (end > -1) {
if (end > offset && src[end - 1] == '\\') {
expression.append(src, offset, end - offset - 1).append(closeToken);
offset = end + closeToken.length();
end = text.indexOf(closeToken, offset);
} else {
expression.append(src, offset, end - offset);
break;
}
}
if (end == -1) {
builder.append(src, start, src.length - start);
offset = src.length;
} else {
String tmp = args[argsIndex] == null ? "" : args[argsIndex].toString();
String value = (argsIndex <= args.length - 1) ? tmp : expression.toString();
builder.append(value);
offset = end + closeToken.length();
argsIndex++;
}
}
start = text.indexOf(openToken, offset);
}
if (offset < src.length) {
builder.append(src, offset, src.length - offset);
}
return builder.toString();
}
public static String parse0(String text, Object... args) {
return PlaceholderParse.parse("${", "}", text, args);
}
public static String parse1(String text, Object... args) {
return PlaceholderParse.parse("{", "}", text, args);
}
public static String parse2(String text, Object... args) {
return PlaceholderParse.parse("#{", "}", text, args);
}
public static String filterInject(Object param) {
String res = param.toString().replaceAll(SQL_INJECT_CHARS, "");
return (param instanceof Number) ? param + "" : res;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下
2020-05-27 基于compose单机部署 etcd + coredns
2020-05-27 Java Mybatis懒加载报错末尾显示_$$_jvst12a_0["handler"])的解决方案