codecamp

12.内置动作定义

12.内置动作定义

概述

在之前的内容当中我们了解到,如果要在决策集、决策表、交叉决策表、决策树、评分卡、复杂评分卡或决策流中使用某个Spring Bean中定义的方法,那么可以使用动作库将目标Bean及相应的方法定义到其中,然后在具体的决策集、决策表、交叉决策表、决策树、评分卡、复杂评分卡或决策流中导入这个动作库就可以使用了,这种类型方法调用,需要我们的显式的将目标动作库导入后方可使用。

在URule Pro中还提供了一种不需要导入动作库就可以调用类方法的方式,我们称之为内置的动作,对于这些内置的动作,按规范要求定义好后,用户无需导入就可以直接在所有规则文件中使用。

对于内置动作的使用与用户自定义的动作库完全相同,不同地方在于内置动作不需要用户定义,也不需要用户导入,在任何一个决策集、决策表、交叉决策表、决策树、评分卡、复杂评分卡或决策流中可以直接使用,如下图所示:

如上图所示,URule Pro中目前默认提供的内置动作有七个,分别用于获取当前规则以及针对日期、字符串、常用数学函数、List集合、Map集合以及循环操作的计算。

  • 当前规则的内置动作

    该内置动作只能在规则的那么部分使用,不能在规则的条件中使用,否则会产生错误。 该内置动作在2.1.9及以上版本中提供 方法名 描述
    当前规则对象 返回当前规则对象Rule
    当前规则名 返回当前规则的字符串类型的规则名称
    当前规则匹配的条件 返回当前规则在匹配时所经历的条件节点对象集合,返回的是一个Set集合对象,里面是若干个Criteria对象

  • 日期的内置动作

方法名 描述
格式化日期 对给定日期按指定格式进行格式化,返回字符串。它需要两个参数:"目标日期","格式";目标日期是进行格式化的日期对象,格式是指怎样对这个日期进行格式化,它采用的是java中的日期格式化模式,常用值如:yyyy-MM-dd HH:mm:ss或yyyy年MM月dd日等
加日期 对给定日期的年月日时分秒各字符添加值,返回日期对象,参数:"目标日期","年数","月数","天数","小时","分钟","秒数";如果只加其中某些区段,那么其它的可以加0,也就是不加。
日期加年 对给定日期的增加指定的年数,返回日期对象,参数:"目标日期","年数"。
日期加月 对给定日期的增加指定的月数,返回日期对象,参数:"目标日期","月数"。
日期加天 对给定日期的增加指定的天数,返回日期对象,参数:"目标日期","天数"。
日期加小时 对给定日期的增加指定的小时数,返回日期对象,参数:"目标日期","小时数"。
日期加分钟 对给定日期的增加指定的分钟数,返回日期对象,参数:"目标日期","分钟数"。
日期加秒 对给定日期的增加指定的秒数,返回日期对象,参数:"目标日期","秒数"。
减日期 对给定日期的年月日时分秒各字符减值,返回日期对象,参数:"目标日期","年数","月数","天数","小时","分钟","秒数";如果只减其中某些区段,那么其它的可以减0,也就是不减。
减日期减年 对给定日期的减指定的年数,返回日期对象,参数:"目标日期","年数"。
减日期减月 对给定日期的减指定的月数,返回日期对象,参数:"目标日期","月数"。
减日期减天 对给定日期的减指定的天数,返回日期对象,参数:"目标日期","天数"。
减日期减小时 对给定日期的减指定的小时数,返回日期对象,参数:"目标日期","小时数"。
减日期减分钟 对给定日期的减指定的分钟数,返回日期对象,参数:"目标日期","分钟数"。
减日期减秒 对给定日期的减指定的秒数,返回日期对象,参数:"目标日期","秒数"。
取年份 取指定日期的年份,返回数字,参数:"目标日期"
取月份 取指定日期的月份,返回数字,参数:"目标日期"
取星期 取指定日期的星期,返回数字,参数:"目标日期"
取天 取指定日期的天,返回数字,参数:"目标日期"
取小时 取指定日期的小时,返回数字,参数:"目标日期"
取分钟 取指定日期的分钟,返回数字,参数:"目标日期"
取秒 取指定日期的秒,返回数字,参数:"目标日期"
日期相减返回毫秒 两个日期相差操作,返回毫秒,参数:"日期","减去的日期"
日期相减返回秒 两个日期相差操作,返回秒,参数:"日期","减去的日期"
日期相减返回分钟 两个日期相差操作,返回分钟,参数:"日期","减去的日期"
日期相减返回小时 两个日期相差操作,返回小时,参数:"日期","减去的日期"
日期相减返回天 两个日期相差操作,返回天数,参数:"日期","减去的日期"
日期相减返回星期 两个日期相差操作,返回星期数,参数:"日期","减去的日期"
取指定月份天数 取某个时间段内指定月份的天数,多个月分可以用“,”分隔,比如“10,11,12”,就表示取目标时间段内在10月、11月和12月的天数
取非指定月份天数 与上面的“取指定月份天数”的方法相反,取某个时间段内非指定月份的天数,多个月分可以用“,”分隔,比如“10,11,12”,就表示取目标时间段内非10月、11月和12月的天数

  • 字符串的内置动作

方法名 描述
去空格 去除目标字符串两边空格,返回字符串,参数:"目标字符串"
指定起始的字符串截取 截取指定区段的字符串,返回字符串,参数:"目标字符串","开始位置","结束位置"
指定开始的字符串截取 截取指定开始位置到结束的字符串,返回字符串,参数:"目标字符串","开始位置"
指定结束的字符串截取 截取从第一个字符开始到指定位置结束的字符串,返回字符串,参数:"目标字符串","结束位置"
转小写 将指定字符串换成小写(仅限英文),返回字符串,参数:"目标字符串"
转大写 将指定字符串换成大写(仅限英文),返回字符串,参数:"目标字符串"
获取长度 获取指定字符串长度,返回数字,参数:"目标字符串"
获取字符 获取指定位置字符,返回字符,参数:"目标字符串","位置"
字符首次出现位置 获取指定字符在当中字符串中首次出现的位置,返回数字,参数:"目标字符串","要查找的字符串"
字符最后出现位置 获取指定字符在当中字符串中最后出现的位置,返回数字,参数:"目标字符串","要查找的字符串"
替换字符串 用新字符串替换指定字符串,返回替换后的字符串,参数:"目标字符串","原字符串","新字符串"

  • 常用数学函数的内置动作

方法名 描述
求绝对值 返回一个数字的绝对值,参数:"数字"
求最大值 求给定两个数字中最大的那个数字,返回那个最大的数字,参数:"数字1","数字2"
求最小值 求给定两个数字中最小的那个数字,返回那个最小的数字,参数:"数字1","数字2"
求正弦 返回一个数字的正弦值,参数:"数字"
求余弦 返回一个数字的余弦值,参数:"数字"
求正切 返回一个数字的正切值,参数:"数字"
求余切 返回一个数字的余切值,参数:"数字"
求e为底的对数 返回一个数字以e为底的对数值,参数:"数字"
求10为底的对数 返回一个数字以10为底的对数值,参数:"数字"
四舍五入 返回一个数字四舍五入后的值,参数:“数字”

  • List集合的内置动作

方法名 描述
求List大小 返回给定的一个集合对象的size属性值,这个集合对象必须是List类型 。
求List中所有的数字最大值 参数为一个包含所有数字的集合对象,要求这个集合对象里每个元素都是数字类型,返回这个集合中最大的那个数字元素对象,这个集合对象必须是List类型 。
求List中所有的数字最小值 参数为一个包含所有数字的集合对象,要求这个集合对象里每个元素都是数字类型,返回这个集合中最小的那个数字元素对象,这个集合对象必须是List类型 。
向List中添加对象 参数有两个,分别是"集合对象","要添加的对象",意思是把第二个参数对象值添加到第一个集合中去,这个集合对象必须是List类型,该方法没有返回 值。
集合排序 参数有三个,分别是"集合对象","属性名","排序方式",其中第一个参数这个集合对象必须是List类型;第二个参数为这个集合中对象的某一个属性名,第三个是一个字符串,可选值有"1"、"true"、"正序",这三个值均表示对这个集合中指定属性名按正序排列,其它值则表示按倒序排列,该方法没有返回 值。
抽取集合属性 参数有两个,分别是"集合对象","属性名",第一个参数这个集合对象必须是List类型;第二个参数为这个集合中对象的属性名。该方法的作用就是将这个集合对象中每个元素的指定属性值取出来,放在一个List集合中返回。
从List中删除对象 参数有两个,分别是"集合对象","要删除的对象",第一个参数必须是一个List类型对象,第二个参数是指定要从这个集合中删除的对象,该方法没有返回值。
指定对象是否存在 参数有两个,分别是"集合对象","要判断的对象",第一个参数必须是一个List类型对象,第二个参数是要判断的对象,该方法没有返回一个布尔值。
List是否为空 参数有一个,也就是"集合对象",这个参数必须是一个List类型对象,用于判断当前给定的List对象里有没有元素,该方法返回布尔值。

  • Map集合的内置动作

方法名 描述
添加到Map 该方法的参数有三个,分别是"Map对象","key","value",第一个参数必须是一个Map类型;第二个参数表示要添加对象的Key值;第三个为要添加的具体对象,该方法没有返回值。
从Map中删除 该方法的参数有两个,分别是"Map对象","key",第一个参数必须是一个Map类型;第二个参数表示要删除对象的Key值,该方法没有返回值。
指定Key是否存在 该方法的参数有两个,分别是"Map对象","key",第一个参数必须是一个Map类型;第二个参数表示要判断的对象的Key值,如果指定的key存在返回true,否则返回false.
从Map中取值 该方法的参数有两个,分别是"Map对象","key",第一个参数必须是一个Map类型;第二个参数表示要取的对象的Key值,返回key值对应的对象。
返回Map大小 该方法的参数有一个,就是"Map对象",作用是返回这个Map对象里对象的数量。

  • 循环操作的内置动作

循环操作的动作就一个,那就是中断循环,该动作只能用在循环规则里,用于在一定条件下中断当前的循环规则。

自定义内置动作

在用户使用过程当中,如果有一些自己内部常用的操作,而这些操作在URule Pro中的内置动作中又没有,那么可以利用自定义内置动作的方式定义自己的内置动作。

定义内置动作非常简单,只需要在需要暴露给用户使用的Spring bean中添加相应的annotation即可。我们先来看看URule Pro中提供的针对字符串的内置动作类的部分源代码。

package com.bstek.urule.runtime.builtinaction;
import com.bstek.urule.model.library.action.annotation.ActionBean;
import com.bstek.urule.model.library.action.annotation.ActionMethod;
import com.bstek.urule.model.library.action.annotation.ActionMethodParameter;
/**
 * @author Jacky.gao
 * @since 2015年11月27日
 */
@ActionBean(name="字符串")
public class StringAction {
    @ActionMethod(name="去空格")
    @ActionMethodParameter(names={"目标字符串"})
    public String trim(String str){
        if(str==null){
            return str;
        }
        return str.trim();
    }


    @ActionMethod(name="指定起始的字符串截取")
    @ActionMethodParameter(names={"目标字符串","开始位置","结束位置"})
    public String substring(String str,int start,int end){
        return str.substring(start, end);
    }
    ......
}

可以看到,首先我们需要在”类“层面添加一个名为ActionBean的annotation,它只有一个属性,就是要定义这个内置动作的名称。然后在需要暴露的方法中添加两个annotation,分别是ActionMethod和ActionMethodParameter。ActionMethod是用来定义用户看到的方法名称的,而ActionMethodParameter则是用来定义用户看到的各个参数名称,它的names属性是一个数组,要求给出的描述参数要与当前方法的参数个数匹配,如果小于参数个数,那么用户将会看到后面的参数无描述信息。

在类中定义好这些Annotation之后,将这个类配置到Spring当中,让其成为一个标准的Spring Bean,并为其定义一个Bean Id,这样URule在启动时就会自动加载,并让其成为内置动作,用户就可以直接使用了。

定义内置动作的Spring Bean时,一定不要忘记给这个Spring Bean定义一个Id,这样才能保证规则在任何地方运行都不会出错,这点很关键。

在定义内置动作时需要注意,如果我们规则运行方式采用的是客户端服务器模式(参见第16小节内容介绍),那么必须要保证调用知识包的客户端Spring环境里有这个Bean,且Bean的Id要与动作库定义时的Id保证一至,否则调用会出现错误。

11.规则流
13.代码中调用规则
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }