org.zodiac.script.engine.ognl.OgnlEngine Maven / Gradle / Ivy
package org.zodiac.script.engine.ognl;
import ognl.Ognl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zodiac.commons.crypto.Md5;
import org.zodiac.commons.util.Colls;
import org.zodiac.script.engine.ExecuteResult;
import org.zodiac.script.engine.ListenerSupportEngine;
import org.zodiac.script.engine.ScriptContext;
import java.util.Map;
public class OgnlEngine extends ListenerSupportEngine {
protected final Logger logger = LoggerFactory.getLogger(this.getClass());
protected final Map cache = Colls.concurrentMap();
@Override
public boolean compiled(String id) {
return cache.containsKey(id);
}
@Override
public ScriptContext getContext(String id) {
return cache.get(id);
}
@Override
public boolean remove(String id) {
return cache.remove(id) != null;
}
@Override
public void init(String... contents) throws Exception {}
@Override
public ExecuteResult execute(String id) {
return execute(id, Colls.map());
}
@Override
public boolean compile(String id, String code) throws Exception {
if (logger.isDebugEnabled()) {
logger.debug("compile Ognl {} : {}", id, code);
}
cache.put(id, new OgnlScriptContext(id, Md5.md5Hex(code), Ognl.parseExpression(code)));
return false;
}
@Override
public ExecuteResult execute(String id, Map param) {
if (logger.isDebugEnabled()) {
logger.debug("execute Ognl {} : {}", id, param);
}
ExecuteResult result = new ExecuteResult();
long start = System.currentTimeMillis();
OgnlScriptContext scriptContext = cache.get(id);
try {
if (scriptContext != null) {
doListenerBefore(scriptContext);
scriptContext = cache.get(id);
param = Colls.map(param);
param.putAll(getGlobalVariable());
Object obj = Ognl.getValue(scriptContext.getScript(), param, param);
result.setSuccess(true);
result.setResult(obj);
} else {
result.setSuccess(false);
result.setResult(null);
result.setMessage(String.format("Ognl: %s not found!", id));
}
long end = System.currentTimeMillis();
result.setUseTime(end - start);
} catch (Exception e) {
logger.error("execute SpEL error", e);
result.setException(e);
}
doListenerAfter(scriptContext, result);
return result;
}
class OgnlScriptContext extends ScriptContext {
private Object script;
public OgnlScriptContext(String id, String md5, Object script) {
super(id, md5);
this.script = script;
}
public Object getScript() {
return script;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy