一个替换java字符串中${}或者{}等占位符的工具类

/**
 * 一个替换java字符串中${}或者{}等占位符的工具类
 *
 * @date 2018/5/31
 */
public class ParserUtils {
    /**
     * 将字符串text中由openToken和closeToken组成的占位符依次替换为args数组中的值
     *
     * @param openToken
     * @param closeToken
     * @param text
     * @param args
     * @return
     */
    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;
        // search open token
        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] == '\\') {
                // this open token is escaped. remove the backslash and continue.
                builder.append(src, offset, start - offset - 1).append(openToken);
                offset = start + openToken.length();
            } else {
                // found open token. let's search close token.
                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] == '\\') {
                        // this close token is escaped. remove the backslash and continue.
                        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);
                        // offset = end + closeToken.length()
                        break;
                    }
                }
                if (end == -1) {
                    // close token was not found.
                    builder.append(src, start, src.length - start);
                    offset = src.length;
                } else {
                    ///仅仅修改了该else分支下的个别行代码

                    String value = argsIndex <= args.length - 1 ?
                        (args[argsIndex] == null ? "" : args[argsIndex].toString()) : 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 ParserUtils.parse("${", "}", text, args);
    }

    public static String parse1(String text, Object... args) {
        return ParserUtils.parse("{", "}", text, args);
    }
}

上面这种比较复杂。我自己写了一个

替换/user/{username}/{name} ------>/user/{}/{}的方法

protected static String getChangedString(String str) {
        char[] chars = str.toCharArray();
        Boolean isAppend = true;
        StringBuffer stringBuffer = new StringBuffer();
        for (int i = 0; i < chars.length; i++) {
            char currentChar = chars[i];
            if (isAppend) {
                if (currentChar == '{') {
                    isAppend = false;
                }
                stringBuffer.append(chars[i]);
            } else {
                if (currentChar == '}') {
                    isAppend = true;
                    stringBuffer.append(chars[i]);
                }
            }
        }
        return stringBuffer.toString();
    }

 

转载于:https://www.cnblogs.com/xuerong/p/9120490.html

Java 解析 SQL 替换数值的工具类通常可以用来将 SQL 语句的参数值替换为具体的数值。下面是一个简单的实现: ```java public class SqlUtils { // 将 SQL 语句的参数占位符替换为具体的数值 public static String replaceParams(String sql, Map<String, Object> params) { for (Map.Entry<String, Object> entry : params.entrySet()) { String key = entry.getKey(); Object value = entry.getValue(); if (value instanceof Number) { sql = sql.replace(key, value.toString()); } else { sql = sql.replace(key, "'" + value.toString() + "'"); } } return sql; } public static void main(String[] args) { String sql = "SELECT * FROM table WHERE id = :id AND name = :name"; Map<String, Object> params = new HashMap<>(); params.put(":id", 1); params.put(":name", "John"); String replacedSql = replaceParams(sql, params); System.out.println(replacedSql); } } ``` 在上述代码,`replaceParams` 方法接收一个 SQL 语句和一个参数 `Map`,循环遍历参数 `Map` 的每个键值对,将 SQL 语句的参数占位符替换为具体的数值。如果参数值是一个数字,直接使用 `toString()` 方法进行替换;如果参数值是一个字符串,需要在值的两侧添加单引号。 在 `main` 方法,我们定义了一个 SQL 语句和一个参数 `Map`,调用 `replaceParams` 方法替换 SQL 语句的参数,并打印替换后的 SQL 语句。 这样的工具类可以方便地用于拼接 SQL 语句,并将参数值替换为具体的数值,避免了直接拼接字符串导致的 SQL 注入的风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值