FreeMarker

渲染字符串模板

 package com.example;

import java.io.IOException;
import java.io.InputStream;
import java.io.StringWriter;
import java.io.Writer;
import java.util.Arrays;
import java.util.Map;

import com.alibaba.fastjson.JSON;

import freemarker.cache.StringTemplateLoader;
import freemarker.template.Configuration;
import freemarker.template.Template;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.io.ResourceLoader;

/**
 * @author whilst
 * @date 2017/04/08
 */
public class FreeMarkerUtils {
    private static final Logger logger = LoggerFactory.getLogger(MessageServiceImpl.class);

    private Configuration freeMarkerConfig;

    @Autowired
    private ResourceLoader resourceLoader;

    private void initFreeMarkerTemplate() {
        synchronized (this) {
            if (null != freeMarkerConfig) {
                return;
            }
            freeMarkerConfig = new Configuration(Configuration.VERSION_2_3_25);

            StringTemplateLoader stringLoader = new StringTemplateLoader();
            Arrays.asList("classpath:template/template1.ftl", "classpath:template/template2.ftl").forEach(filepath -> {
                try {
                    InputStream inputStream = resourceLoader.getResource(filepath).getInputStream();
                    String content = IOUtils.toString(inputStream, "UTF-8");
                    stringLoader.putTemplate(filepath, content);
                } catch (IOException e) {
                    logger.error("加载模板文件出错, filepath: [" + filepath + "], 出错原因: ", e);
                }
            });

            freeMarkerConfig.setTemplateLoader(stringLoader);
        }
    }

    private String renderTemplate(String templateName, Map<String, Object> model) {
        initFreeMarkerTemplate();

        Writer out = new StringWriter(10480);
        try {
            Template tpl = freeMarkerConfig.getTemplate(templateName);
            tpl.process(model, out);
        } catch (Exception e) {
            String error = "渲染模板出错, template: [" + templateName + "], model: [" + JSON.toJSONString(model) + "]";
            logger.error(error, e);
            throw new IllegalArgumentException(error, e);
        }

        return out.toString();
    }
}
posted @ 2017-04-08 00:11  whilst  阅读(229)  评论(0)    收藏  举报