本文参考自:https://www.cnblogs.com/studyjobs/p/18125096

规则引擎技术的主要思想是将应用程序中的业务规则分离出来,业务规则不再以程序代码的形式驻留在系统中,而是存储在独立的文件或者数据库中,完全独立于程序。业务人员可以像管理数据一样对业务规则进行管理。业务规则在程序运行时被加载到规则引擎中供应用系统调用。

solon-flow 是新的规则引擎技术,由 OpenSolon 开源组织提供的基于 Java 语言开发的开源规则引擎,可以将复杂且多变的业务规则从硬编码中解放出来,以 yaml 规则脚本的形式存放在文件或特定的存储介质中(例如数据库),使得业务规则的变更不需要修改项目代码、不需要重启服务器就可以立即生效。

本篇博客的 demo 以个税计算器为例,介绍如何使用 solon-flow 规则引擎,有关具体技术细节,限于篇幅有限,这里不会介绍,具体细节可以参考官网。

solon-flow 官网地址:https://solon.noear.org/article/learn-solon-flow

solon-flow 源码下载地址:https://gitee.com/opensolon/solon/tree/main/solon-projects/solon-flow/solon-flow

1、搭建工程

搭建一个 solon 工程,结构如下:

solon-flow 规则引擎将规则编写在以 .yml (很流行的配置文)为后缀的文件中,yml 文件默认也是使用 yaml + java 语言编写,所以学习起来很容易。

一般情况下,我们使用 IDEA 编写业务规则,默认情况下 .yml 文件会被打包到项目 jar 包中,为了方便后续调整规则,我们可以将 yml 文件的内容,存储到数据库中或者 oss 云盘中,程序在运行时从 jar 包外部读取规则内容。

完束上的 pom 文件的内容:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <parent>
<groupId>org.noear</groupId>
<artifactId>solon-parent</artifactId>
<version>3.0.8</version>
<relativePath />
</parent> <groupId>com.example</groupId>
<artifactId>demo-rule</artifactId>
<version>1.0</version> <properties>
<java.version>11</java.version>
</properties> <dependencies>
<dependency>
<groupId>org.noear</groupId>
<artifactId>solon-web</artifactId>
</dependency> <!-- 规则与流引擎 -->
<dependency>
<groupId>org.noear</groupId>
<artifactId>solon-flow</artifactId>
</dependency> <dependency>
<groupId>org.noear</groupId>
<artifactId>solon-logging-simple</artifactId>
</dependency> <dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency> <dependency>
<groupId>org.noear</groupId>
<artifactId>solon-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies> <build>
<finalName>${project.artifactId}</finalName> <plugins>
<plugin>
<groupId>org.noear</groupId>
<artifactId>solon-maven-plugin</artifactId>
</plugin>
</plugins>
</build> </project>

2、代码细节展示

此文的 demo 是个税计算器,我们创建一个用于向规则引擎传递数据的实体类

package com.example.demo.model;

import lombok.Data;

@Data
public class Calculation {
//税前工资
private double wage;
//应纳税所得额
private double wagemore;
//税率
private double cess;
//速算扣除数
private double preminus;
//扣税额
private double wageminus;
//税后工资
private double actualwage;
}

这里不考虑缴纳社保和专项扣除等因素,个税计算的规则如下:

之后我们在 flow/rule.yml 中编写的规则如下:

id: rule
nodes:
- id: "tax_setWagemore" #计算应纳税所得额
when: |
import java.time.LocalDate;
//2022-10-1 后生效
return cal.getWage() > 0 && LocalDate.now().compareTo(LocalDate.of(2022,10,1)) > 0;
task: |
double wagemore = cal.getWage() - 5000;
cal.setWagemore(wagemore);
- id: "tax_3000" #设置税率、速算扣除数
when: "cal.getWagemore() <= 3000"
task: |
cal.setCess(0.03);//税率
cal.setPreminus(0);//速算扣除数
- id: "tax_12000"
when: "cal.getWagemore() > 3000 && cal.getWagemore() <= 12000"
task: |
cal.setCess(0.1);//税率
cal.setPreminus(210);//速算扣除数
- id: "tax_25000"
when: "cal.getWagemore() > 12000 && cal.getWagemore() <= 25000"
task: |
cal.setCess(0.2);
cal.setPreminus(1410);
- id: "tax_35000"
when: "cal.getWagemore() > 25000 && cal.getWagemore() <= 35000"
task: |
cal.setCess(0.25);
cal.setPreminus(2660);
- id: "tax_55000"
when: "cal.getWagemore() > 35000 && cal.getWagemore() <= 55000"
task: |
cal.setCess(0.25);
cal.setPreminus(2660);
- id: "tax_80000"
when: "cal.getWagemore() > 55000 && cal.getWagemore() <= 80000"
task: |
cal.setCess(0.35);
cal.setPreminus(7160);
- id: "tax_max"
when: "cal.getWagemore() > 80000"
task: |
cal.setCess(0.45);
cal.setPreminus(15160);
- id: "tax_result"
when: "cal.getWage() > 0 && cal.getWagemore() > 0 && cal.getCess() > 0"
task: |
//扣税额
double wageminus = cal.getWagemore() * cal.getCess() - cal.getPreminus();
double actualwage = cal.getWage() - wageminus;
cal.setWageminus(wageminus);
cal.setActualwage(actualwage);
System.out.println("--税前工资:"+cal.getWage());
System.out.println("--应纳税所得额:"+cal.getWagemore());
System.out.println("--税率:" + cal.getCess());
System.out.println("--速算扣除数:" + cal.getPreminus());
System.out.println("--扣税额:" + cal.getWageminus());
System.out.println("--税后工资:" + cal.getActualwage());

本 demo 设定每次被调用时,都去读取 rule.yml 的内容(可时实生效),具体代码在 RuleService 中实现:

package com.example.demo.dso;

import com.example.demo.model.Calculation;
import org.noear.solon.annotation.Component;
import org.noear.solon.annotation.Inject;
import org.noear.solon.flow.ChainContext;
import org.noear.solon.flow.FlowEngine; @Component
public class RuleService {
//调用Drools规则引擎实现个人所得税计算
public Calculation calculate(Calculation calculation) throws Throwable {
FlowEngine flowEngine = FlowEngine.newInstance();
flowEngine.load(Chain.parseByUri("file:src/main/resources/flow/rule.yml")); //动态加载源码下的文件,修改后实时生效 //构建上下文
ChainContext ctx = new ChainContext();
ctx.put("cal", calculation); //执行规则
flowEngine.eval("rule", ctx); //返回运行算后的
return calculation;
}
}

然后在 RuleController 中对外提供计算个税的接口,只需要传递一个税前工资额即可计算得出结果

@Mapping("rule")
@Controller
public class RuleController {
@Inject
RuleService ruleService; @Mapping("calculate")
public Calculation calculate(double wage) throws Throwable {
Calculation calculation = new Calculation();
calculation.setWage(wage);
calculation = ruleService.calculate(calculation);
System.out.println(calculation);
return calculation;
}
}

3、验证成果

启动后,可以访问接口 http://localhost:8080/rule/calculate?wage=10000 即可查看到静态页面,输入 10000 元计算个税,如下图:

结果可以发现,税率是 0.1,执行的是 rule.yml 文件中的名称为 tax_12000 的规则,此时你可以使用 IDEA 修改一下,比如将税率修改为 0.2

  - id: "tax_12000"
when: "cal.getWagemore() > 3000 && cal.getWagemore() <= 12000"
task: |
cal.setCess(0.2);//这里故意将税率修改为 0.2
cal.setPreminus(210);//速算扣除数

注意不需要重启 IDEA 的项目(可时实生效),此时重新点击页面中的计算,发现刚刚修改的规则生效了,如下图所示:

好了,以上就是有关 solon 使用 drools 规则引擎的介绍(在 spring 里差不多),有兴趣的话可以下载源代码进行验证。

本示例,源码下载地址:

https://gitee.com/opensolon/solon-flow_rule-demo

快速集成和使用 solon-flow 规则与流引擎(用 yaml 编写业务规则)的更多相关文章

  1. 第2-4-2章 规则引擎Drools入门案例-业务规则管理系统-组件化-中台

    目录 3. Drools入门案例 3.1 业务场景说明 3.2 开发实现 3.3 小结 3.3.1 规则引擎构成 3.3.2 相关概念说明 3.3.3 规则引擎执行过程 3.3.4 KIE介绍 3. ...

  2. 第2-4-3章 规则引擎Drools基础语法-业务规则管理系统-组件化-中台

    目录 4. Drools基础语法 4.1 规则文件构成 4.2 规则体语法结构 4.3 注释 4.4 Pattern模式匹配 4.5 比较操作符 4.5.1 语法 4.5.2 操作步骤 4.6 执行指 ...

  3. 第2-4-5章 规则引擎Drools高级语法-业务规则管理系统-组件化-中台

    目录 6. Drools高级语法 6.1 global全局变量 6.2 query查询 6.3 function函数 6.4 LHS加强 6.4.1 复合值限制in/not in 6.4.2 条件元素 ...

  4. 第2-4-1章 规则引擎Drools介绍-业务规则管理系统-组件化-中台

    目录 规则引擎 Drools 1. 问题引出 2. 规则引擎概述 2.1 什么是规则引擎 2.2 使用规则引擎的优势 2.3 规则引擎应用场景 2.4 Drools介绍 规则引擎 Drools 全套代 ...

  5. 快速集成iOS基于RTMP的视频推流

    前言 这篇blog是iOS视频直播初窥:<喵播APP>的一个补充. 因为之前传到github上的项目中没有集成视频的推流.有很多朋友简信和微博上问我推流这部分怎么实现的. 所以, 我重新集 ...

  6. 快速集成图片浏览器快速集成图片浏览器->MJPhotoBrowser的使用

    介绍: 一个比较完整的图片浏览器,高仿了新浪微博的图片浏览效果,功能包括:下载浏览互联网图片,点击缩略图全屏显示图片.当加载较大图片时会出现圆形进度条,滑动浏览所有图片.保存图片到本地相册.GIF图片 ...

  7. iOS简单快速集成Cordova

    如果你对于什么是Cordova还不了解,可以先移步到我另一个文章:Cordoval在iOS中的运用整理 里面有详细的介绍跟如何搭建Cordova:而本文则是要介绍JiaCordova插件,如果你有一点 ...

  8. Spring Boot 揭秘与实战(三) 日志框架篇 - 如何快速集成日志系统

    文章目录 1. 默认的日志框架 logback2. 常用的日志框架 log4j 1.1. 日志级别 1.2. 日志文件 3. 源代码 Java 有很多日志系统,例如,Java Util Logging ...

  9. Android Studio快速集成讯飞SDK实现文字朗读功能

    今天,我们来学习一下怎么在Android Studio快速集成讯飞SDK实现文字朗读功能,先看一下效果图: 第一步 :了解TTS语音服务 TTS的全称为Text To Speech,即“从文本到语音” ...

  10. ShareSDK入门指南:Android 10分钟快速集成

    ShareSDK 官方已提供Android 快速集成教程,以官方教程为参考,本文重点指导大家在集成中遇到的问题. Android 快速集成官方教程:http://wiki.mob.com/Androi ...

随机推荐

  1. Win10多用户同时登陆

    1. 说明: (1)Win服务器版默认是支持多用户登陆的,甚至可以在主机上用不同用户自己远程登陆自己,如window server 2016. (2)Win10正常情况下是不允许用户同时远程的,即一个 ...

  2. docker环境一个奇怪的问题,容器进程正常运行,但是docker ps -a却找不到容器,也找不到镜像

    一: 问题: docker环境一个奇怪的问题,使用容器跑的进程正常提供服务,在服务器上也能看到对应的端口正在监听,但是docker ps -a却找不到容器,也找不到镜像. 查看我使用docker容器启 ...

  3. 下列哪个选项是对ICMP FLOOD攻击的正确描述?

    A.  通过重复发送HTTP GET请求,将内容传输的负载施加到攻击目标服务器上. B.  通过使用ping命令发送大量请求包,导致通向被攻击服务器过载并阻止访问. C.  通过发送与连接启动请求对应 ...

  4. vscode代码注释插件koroFileHeader配置(自用)

    前言 一直以来写注释都是让人头疼的问题,力求保持注释风格统一也很麻烦,偶然间发现的这款vscode中的注释插件koroFileHeader,配置好后可以大大提高写注释的效率与积极性♪(∇*) 安装插件 ...

  5. PDFsharp 1.50

    PDFsharp 1.50 Preview Information - PDFsharp & MigraDoc PDFShapr 1.50 修复与改进 支持 Object Streams - ...

  6. 尝试新的 System.Text.Json 源生成器

    尝试新的 System.Text.Json 源生成器 在 .NET 6.0 的预览版中,我们使用 System.Text.Json 发布了一个新的 C# source generator 来帮助改进应 ...

  7. 关于 JavaScript 中的 Array.reduce()

    关于 JavaScript 中的 Array.reduce() reduce() 方法在 MDN 的定义看起来很复杂: reduce((previousValue, currentValue, cur ...

  8. 浅聊web前端性能测试

    最近正好在做web前端的性能测试,这次就来聊聊关于这个的测试思路~ 首先从用户的思维去思考,关于web前端性能,用户最看重的是什么...... 其实就是下面三个点: 1. 加载性能(即页面加载时间+资 ...

  9. Windows10中安装了ubuntu虚拟机后xshell无法连接到ubuntu

    安装了ubuntu虚拟机后发现shell无法连接到ubuntu的排查步骤: 步骤 1: 检查虚拟机网络配置确认虚拟机网络模式:确认虚拟机的网络模式是否设置为桥接模式或NAT模式.桥接模式可以让你的虚拟 ...

  10. [转]CMake学习笔记(一)基本概念介绍、入门教程及CLion安装配置

    原文链接:CMake学习笔记(一)基本概念介绍.入门教程及CLion安装配置