使用SpringEL功能來動態化模板數據

在相似excel導出功能裏,若是excel的格式很複雜,經過程序去動態生成格式顯然是很吃力的,咱們能夠採用模板文件+動態表達式佔位來生成目標文件。html

若是隻是純粹生成純文本,使用freemarker等模板解析引擎也能夠實現。能夠參考個人另一篇blog:http://www.javashuo.com/article/p-pekpllio-hw.htmljava

下面這個是SpringEL的簡單單元測試類:spring

import static org.junit.Assert.assertEquals;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.junit.Test;
import org.springframework.boot.autoconfigure.security.SecurityProperties.User;
import org.springframework.expression.EvaluationContext;
import org.springframework.expression.ExpressionParser;
import org.springframework.expression.spel.standard.SpelExpressionParser;
import org.springframework.expression.spel.support.StandardEvaluationContext;

public class SpringELTest {    
    @Test
    public void test2() {
        Map<String, String> map = new HashMap<>();
        map.put("key1", "value1");
        
        User user = new User();
        user.setName("zhangsan");
        
        ExpressionParser parser = new SpelExpressionParser();
        EvaluationContext context = new StandardEvaluationContext();
        context.setVariable("str", "xxx");
        context.setVariable("map", map);
        context.setVariable("user", user);
        
        String value = parser.parseExpression("#str").getValue(context, String.class);
        assertEquals("xxx", value);
        
        value = parser.parseExpression("#map.get(\"key1\")").getValue(context, String.class);
        assertEquals("value1", value);
        
        value = parser.parseExpression("#user.name").getValue(context, String.class);
        assertEquals("zhangsan", value);
    }
}

 更多用法能夠參考官方文檔地址:https://docs.spring.io/spring/docs/3.0.x/reference/expressions.htmlexpress

相關文章
相關標籤/搜索