问题引出
现有一个在线申请信用卡的业务场景,用户需要录入个人信息,如下图所示
通过上图可以看到,用户录入的个人信息包括姓名、性别、年龄、学历、电话、所在公司、职位、月收入、是否有房、是否有车、是否有信用卡等。录入完成后点击申请按钮提交即可。
用户提交申请后,需要在系统的服务端进行用户信息合法性检查(是否有资格申请信用卡),只有通过合法性检查的用户才可以成功申请到信用卡(注意:不同用户有可能申请到的信用卡额度不同)
检查用户信息合法性的规则如下:
用户信息合法性检查通过后,还需要根据如下信用卡发放规则确定用户所办信用卡的额度
思考:如何实现上面的业务逻辑呢?
我们最容易想到的就是使用分支判断(if else)来实现,例如通过如下代码来检查用户信息合法性
如果用户信息合法性检查通过后,还需要通过如下代码确定用户所办信用卡的额度。
通过以上伪代码我们可以看到,我们的业务规则是通过Java代码的方式实现的。这种实现方式存在如下问题: 1、硬编码实现业务规则难以维护 2、硬编码实现业务规则难以应对变化 3、业务规则发生变化需要修改代码,重启服务后才能生效
那么面对上面的业务场景,还有什么好的实现方式吗?
答:Drools 规则引擎