前端代码地址:https://gitee.com/qwding/rule-engine-front
项目展示地址:http://ruleengine.cn/
申请登录权限联系QQ:761945125,Email:761945125@qq.com
如果项目在使用过程中,发现项目缺陷或者漏洞等问题,可以在以下地址中提出问题反馈:
Gitee:https://gitee.com/qwding/rule-engine/issues
Github:https://github.com/rule-engine/rule-engine/issues
提出一个问题奖励2元(请大家不要嫌少哦!此项目属于非盈利项目,纯属个人兴趣开源以及开发,我们只想把此项目更加完善!)
提出问题后请联系作者打款。
注意:
- 每天奖励数量最多10个。
- 重复问题没有奖励。
简单使用:https://blog.csdn.net/weixin_42756198/article/details/109680143
详细文档:http://ruleengine.cn/doc
- 所涉及的相关的技术有:
- SpringBoot 2.1.2
- RabbitMQ
- Redis、Redisson
- MySQL 5.7.9
- Mybatis-plus
- Mybatis-plus-generator
- Maven 3.3
- Swagger
通过在 http://ruleengine.cn 配置规则,例如配置的规则如下:
规则配置信息展示 |
---|
配置完成后我们就可以调用接口来执行引擎中的规则了
POST http://ruleserver.cn/ruleEngine/generalRule/execute
Content-Type: application/json
{
"code": "phoneRuletest",
"workspaceCode": "default",
"accessKeyId": "略",
"accessKeySecret": "略",
"param": {
"phone": "13400000000"
}
}
现在我们让此使用方式更加简单易用! 调用规则方项目pom.xml文件引入以下依赖
<dependency>
<groupId>cn.ruleengine</groupId>
<artifactId>rule-engine-client</artifactId>
<version>1.8</version>
</dependency>
SpringBoot项目application.yml配置文件配置如下:
rule.engine:
baseUrl: http://ruleserver.cn
workspaceCode: default
accessKeyId: root
accessKeySecret: 123456
# 可选配置
feignConfig:
request:
connectTimeoutMillis: 3000
readTimeoutMillis: 3500
retryer:
period: 2000
maxPeriod: 2000
maxAttempts: 3
然后编写如下代码进行测试:
@EnableRuleEngine
@RunWith(SpringRunner.class)
@SpringBootTest
public class RuleTest {
@Resource
private RuleEngineClient ruleEngineClient;
@Test
public void test() {
// 构建规则请求参数
PhoneTestRule phoneTestRule = new PhoneTestRule();
phoneTestRule.setPhone("134000000000");
// 调用执行引擎中的规则
GeneralRule generalRule = this.ruleEngineClient.generalRule();
Output output = generalRule.execute(phoneTestRule);
System.out.println(output);
}
}
@Data
@Model(code = "phoneRuletest")
public class PhoneTestRule {
/**
* ElementField可选,默认code为属性name
*/
@ElementField(code = "phone")
private String phone;
}
我们默认使用Feign请求,当然你也可以自定义,只需要在项目中配置如下代码:
public class RuleEngineClientConfig {
@Bean
public GeneralRuleInterface generalRuleInterface() {
return new GeneralRuleInterface() {
@Override
public ExecuteResult execute(ExecuteParam executeParam) {
return restTemplate.postForObject("http://ruleserver.cn/ruleEngine/generalRule/execute", executeParam, ExecuteResult.class);
}
@Override
public IsExistsResult isExists(IsExistsParam existsParam) {
// TODO: 2020/12/30
return null;
}
@Override
public BatchExecuteResult batchExecute(BatchParam batchParam) {
// TODO: 2020/12/30
return null;
}
};
}
}
现在你就已经学会了如何使用,更多使用方式敬请期待!
- 规则版本(开发中)
- 规则监控(待开发)
- 评分卡(待开发)
- 决策树(待开发)
- 元素组(待开发)
- 提供规则、规则集、决策表延迟加载功能,以及定时清理长时间未使用的规则、规则集、决策表功能(待开发)
目前忙于工作,功能待完善,欢迎有兴趣伙伴加入我们!