首页
/ Easy Rules 开源项目教程

Easy Rules 开源项目教程

2026-01-16 10:14:14作者:余洋婵Anita

项目介绍

Easy Rules 是一个简单而愚蠢的 Java 规则引擎,灵感来源于 Martin Fowler 的文章 "Should I use a Rules Engine?"。Easy Rules 提供了一个规则引擎的基本功能,包括定义规则、条件和动作,并能够在满足条件时执行相应的动作。该项目自 2020 年 12 月起进入维护模式,目前仅支持版本 4.1.x,建议用户升级到此版本。

项目快速启动

安装 Easy Rules

首先,在您的 Maven 项目中添加 Easy Rules 的依赖:

<dependency>
    <groupId>org.jeasy</groupId>
    <artifactId>easy-rules-core</artifactId>
    <version>4.1.0</version>
</dependency>

创建并运行规则

以下是一个简单的例子,展示如何定义一个规则并运行它:

import org.jeasy.rules.api.Facts;
import org.jeasy.rules.api.Rules;
import org.jeasy.rules.api.RulesEngine;
import org.jeasy.rules.core.DefaultRulesEngine;
import org.jeasy.rules.core.RuleBuilder;

public class Test {
    public static void main(String[] args) {
        // 定义规则
        Rule weatherRule = new RuleBuilder()
            .name("weather rule")
            .description("if it rains then take an umbrella")
            .when(facts -> facts.get("rain").equals(true))
            .then(facts -> System.out.println("It rains, take an umbrella!"))
            .build();

        // 注册规则
        Rules rules = new Rules();
        rules.register(weatherRule);

        // 定义事实
        Facts facts = new Facts();
        facts.put("rain", true);

        // 运行规则引擎
        RulesEngine rulesEngine = new DefaultRulesEngine();
        rulesEngine.fire(rules, facts);
    }
}

应用案例和最佳实践

应用案例

Easy Rules 可以应用于多种场景,例如:

  • 天气预警系统:根据天气条件触发不同的预警动作。
  • 电商系统:根据用户行为和购物车内容推荐商品或提供优惠。
  • 金融系统:根据市场条件和用户投资组合执行自动交易。

最佳实践

  • 模块化规则:将复杂的业务逻辑分解为多个简单的规则,便于管理和维护。
  • 使用注解:通过在 POJO 类上添加 @Rule 注解来定义规则,使代码更简洁。
  • 测试驱动开发:在开发规则时,使用单元测试确保每个规则的行为符合预期。

典型生态项目

Easy Rules 支持多种表达式语言,如 Apache JEXL、MVEL 和 SpEL。此外,还有一些社区贡献的端口和扩展,例如:

  • EasyRulesGo:Easy Rules 的 Golang 端口,由 @jiminoc 开发。
  • EasyRulesGroovy:Easy Rules 教程的 Groovy 版本,由 @will-gilbert 开发。
  • EasyRulesCsharp:Easy Rules 的 C# 端口(正在进行中),由 @feldrim 开发。

这些生态项目扩展了 Easy Rules 的应用范围,使其能够适应更多编程语言和环境。

登录后查看全文
热门项目推荐
相关项目推荐