java得到字符串String的比较表达式的结果*
- 工作中遇到这样的需求用户想要直接输入比较表达式,来过滤他所需要的数据。类型与这样的格式:
(链路流入速率 > 20 and 链路流入速率 <= 50.2 and 链路流出速率 > 10) or 链路流出利用率 < 100
- 但是数据在redis中并不能直接sql进行拼接筛选。所以我们可以使用java执行js代码的方法来得到结果。
解决的核心:
- 先用字符串替换。把字段 流入速率 替换成字段的属性值。(30.0 > 20 && 30.0 <= 50.2 && 0.0 > 10) || 50.0 < 100
- 将上面的表达式作为javascript代码执行的得到结果。
- 核心代码块
ScriptEngine engine = manager.getEngineByName("javascript");
Bindings bindings = engine.getBindings(ScriptContext.ENGINE_SCOPE);
try {
engine.eval("c=" + condition);
isConform = (Boolean) engine.get("c");
} catch (ScriptException e) {
e.printStackTrace();
}
执行的效果: