|
|
@ -1,49 +1,57 @@
|
|
|
|
package org.opsli.core.creater.utils;
|
|
|
|
package org.opsli.core.creater.utils;
|
|
|
|
|
|
|
|
|
|
|
|
import cn.hutool.core.io.IoUtil;
|
|
|
|
import cn.hutool.core.io.IoUtil;
|
|
|
|
|
|
|
|
import com.google.common.collect.Maps;
|
|
|
|
import com.jfinal.kit.Kv;
|
|
|
|
import com.jfinal.kit.Kv;
|
|
|
|
import com.jfinal.template.Engine;
|
|
|
|
import com.jfinal.template.Engine;
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
|
|
|
import org.apache.commons.lang3.StringUtils;
|
|
|
|
import org.springframework.core.io.ClassPathResource;
|
|
|
|
import org.springframework.core.io.ClassPathResource;
|
|
|
|
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
|
|
|
import java.io.InputStream;
|
|
|
|
import java.io.InputStream;
|
|
|
|
import java.nio.charset.StandardCharsets;
|
|
|
|
import java.nio.charset.StandardCharsets;
|
|
|
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
|
|
|
|
|
|
/***
|
|
|
|
/***
|
|
|
|
* jfinal魔板引擎
|
|
|
|
* Enjoy 模板引擎
|
|
|
|
* @author dufuzhong
|
|
|
|
* @author Parker
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
@Slf4j
|
|
|
|
@Slf4j
|
|
|
|
public final class EnjoyUtil {
|
|
|
|
public final class EnjoyUtil {
|
|
|
|
|
|
|
|
|
|
|
|
private static final String BASE_PATH = "/tpl";
|
|
|
|
private static final String BASE_PATH = "/tpl";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** 模板文件Map */
|
|
|
|
|
|
|
|
private static final Map<String, String> TEMPLATE_FILE_MAP = Maps.newConcurrentMap();
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* 根据具体魔板生成文件
|
|
|
|
* 根据具体魔板生成文件
|
|
|
|
* @param templateFileName 模板文件名称
|
|
|
|
* @param templateFileName 模板文件名称
|
|
|
|
* @param kv 渲染参数
|
|
|
|
* @param kv 渲染参数
|
|
|
|
* @return
|
|
|
|
* @return String
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public static String render(String templateFileName, Kv kv) {
|
|
|
|
public static String render(final String templateFileName, Kv kv) {
|
|
|
|
|
|
|
|
|
|
|
|
String str = "";
|
|
|
|
// 模板缓存 减少每次更新
|
|
|
|
ClassPathResource resource = new ClassPathResource(BASE_PATH + templateFileName);
|
|
|
|
String templateFile = TEMPLATE_FILE_MAP.get(templateFileName);
|
|
|
|
try (InputStream inputStream = resource.getInputStream()){
|
|
|
|
if(StringUtils.isEmpty(templateFile)){
|
|
|
|
String readTpl = IoUtil.read(inputStream, StandardCharsets.UTF_8);
|
|
|
|
|
|
|
|
|
|
|
|
// 如果为空 则IO 读取原始文件
|
|
|
|
str = Engine.use()
|
|
|
|
ClassPathResource resource = new ClassPathResource(BASE_PATH + templateFileName);
|
|
|
|
// 开启预热模式
|
|
|
|
try (InputStream inputStream = resource.getInputStream()){
|
|
|
|
.setDevMode(true)
|
|
|
|
templateFile = IoUtil.read(inputStream, StandardCharsets.UTF_8);
|
|
|
|
.getTemplateByString(readTpl)
|
|
|
|
TEMPLATE_FILE_MAP.put(templateFileName, templateFile);
|
|
|
|
.renderToString(kv);
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
|
|
|
log.error("load file {} error", templateFileName, e);
|
|
|
|
} catch (Exception e) {
|
|
|
|
}
|
|
|
|
log.error("load config file {} error", templateFileName, e);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return str;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return Engine.use()
|
|
|
|
|
|
|
|
// 开启预热模式
|
|
|
|
|
|
|
|
.setDevMode(true)
|
|
|
|
|
|
|
|
.getTemplateByString(templateFile)
|
|
|
|
|
|
|
|
.renderToString(kv);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private EnjoyUtil(){}
|
|
|
|
private EnjoyUtil(){}
|
|
|
|