最近在项目中遇到了一个问题,前端传来一个字符串,其结构类似于(AAA&&BBB)||(CCC||DDD)这种,是一个条件判断的字符串,如果我们自己编写算法来解析这个字符串最后输出结果是true还是false,那么未免显得有些麻烦,JDK中实际上已经有一套这样的算法(if关键字),我们要做的只是实现编译字符串格式的JAVA代码。
实现这样的功能要依赖于org.apache.commons。
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-jexl --> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-jexl</artifactId> <version>2.1.1</version> </dependency>
具体实现思路及代码如下:
一种思路是先将字符串中的AAA、BBB替换成true和false,因为对于单个字符串的true和false我们很好判断,可以利用正则表达式去将字符串中的AAA等提取出来单个判断,然后进行替换。随后执行的代码如下,code就是替换后的字符串。
String code = “这是代码”; JexlEngine jexl = new JexlEngine(); Expression e = jexl.createExpression(code); Object result = e.evaluate(null);
如果字符串中存在参数,需要对参数进行赋值,代码如下。
其中result就是返回值。JexlContext jc = JexlHelper.createContext(); jc.getVars().put("AAA", false); jc.getVars().put("BBB", true); Object result = e.evaluate(jc);
JAVA使用commons-jexl实现编译字符串中的代码
最新推荐文章于 2024-08-07 09:27:26 发布