前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spel 表达式

Spel 表达式

原创
作者头像
冯文议
发布2024-03-29 22:40:15
980
发布2024-03-29 22:40:15

模板占位替换,在项目开发中,还是很常用的。比如在代码中获取参数,消息推送可以使用变量占位,我比较推荐使用 SPEL 表达式。

  1. 在注解中,获取方法的参数
代码语言:java
复制
public class SpElParser {

    private static final ExpressionParser parser = new SpelExpressionParser();

    public static String getKey(String key, String [] parameterNames, Object [] args) {
        Expression expression = parser.parseExpression(key);
        EvaluationContext context = new StandardEvaluationContext();
        if (args.length == 0) {
            return null;
        }
        for (int i = 0; i < args.length; i++) {
            context.setVariable(parameterNames[i], args[i]);
        }
        return expression.getValue(context, String.class);
    }

}

用法:

@LogRecord(logBizId = "#dto.id")

@LogRecord(logBizId = "#dto.id + '_' + #dto.name")

  1. 模板占位替换
代码语言:java
复制
    public static String convert(String content, Map<String, String> paramMap) {
        if (!StringUtils.hasText(content) || CollectionUtils.isEmpty(paramMap)) {
            return content;
        }
        ExpressionParser parser = new SpelExpressionParser();
        TemplateParserContext parserContext = new TemplateParserContext();
        return parser
                .parseExpression(content, parserContext)
                .getValue(paramMap, String.class);
    }

    public static String convert(String content, String json) {
        if (!StringUtils.hasText(content) || !StringUtils.hasText(json)) {
            return content;
        }
        Map<String, String> paramMap = JacksonUtils.jsonObject(
                json,
                new TypeReference<Map<String, String>>() {
                }
        );
        return convert(content, paramMap);
    }
代码语言:json
复制
{
    "name":"张三"
}

用法1,变量占位替换

代码语言:java
复制
String content = "#{[name]}";

用法2,变量占位替换 + 字符串拼接

代码语言:java
复制
String content = "#{'Hello, ' + [name] + '!'}"; 

用法3,判断变量是否为空

代码语言:java
复制
String content = "#{[name1] != null ? 'Hello, ' + [name1] + '!' : ''}"; 

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档