java隨記

          堅持就是勝利!

           

          業務規則與自定義規則處理庫

          前篇隨筆《需求收集、分析》中簡單提了一下業務規則。業務規則是很重要的一個東西,并且用戶對于業務規則也極易
          更改或者新增新的業務規則.尤其是在某些場合如促銷,積分商城等場景。正因為規則如此重要,建議使用單獨的文檔
          維護,規則名稱編號可以與用例名稱編對一一對應。
          業務規則分類:
          一,內稟規則:業務實體本身的規則。如訂單中銷售記錄不能為空,數量不能為等。
          二,全局規則:一般與所有用例相關而不是某個特定用例相關。例如系統安全方面的sql注入,ddos攻擊等。
          三,交互規則:用于用例當中。它們規定了滿足什么條件后業務將如何反應。有些規則需要開發成系統用例。比如人事
          管理系統中請假業務只有工作日才計入請假天數,那么這個工作日就需要電腦來維護了,會作為一個系統用例存在,并
          且作為請假用例的前置條件。 交互規則又是最容易引起.
          交互規則如此靈活多變,需要良好的設計才能保證系統的擴展性和可維護性。如何做:
          思路一:
              在 j
          avax.swing.border包提供了Border接口和幾個不同的Boder的實現。在swing中每個組件提供了paint方法,每
          個組件知道怎么畫自己展示自己的外觀。那么我們可以提供業務規則處理接口,每個具體業務規則自己知道怎么處理業務。
          可以用簡單工廠來決定調用哪一個具體業務規則。這個是策略模式的使用,缺點是新增具體業務時工廠類會修改。也可以
          用觀察者模式來實現,所有的具體業務類都來觀察這個業務規則,自己判斷是不是自己可以處理的,不是就不理會。
          基于策略模式的規則實現類圖:

          思路二:
               規則引擎比如drools處理一些問題 。
          規則引擎適合于做業務規則頻繁變化的場景.把業務規則抽出來通過規則引擎來
          處理。類似工作流系統的概念。

          自定義規則處理庫:
               一些動態的語言很適合來做這樣的事情。java支持script.Mvel是一個表達式語言,drools也支持mvel來處理業務規則.
          這里自定義規則引擎使用Mvel表達式語言.
                規則文件示例:
               
          <rules>
                 <!--rule-set 是一個規則集,執行規則 rule1時會迭代規則集里面所有的規則(mvel-rule)-->
          <rule-set name="rule1">
          <!-- id是規則的標識,也是默認的排序處理順序。exclusive 是排它。如果為true,則當前規則執行后,不再執行后面的規則-->
          <mvel-rule id="step1"  exclusive="false">
          <block><![CDATA[
          if(salary<=3500) {result=0;}
          ]]></block>
          </mvel-rule>
          <mvel-rule id="step2" exclusive="false">
          <block><![CDATA[if(salary>3500) {result=1};]]></block>
          </mvel-rule>
          </rule-set>
          <rule-set name="rule2">
          <mvel-rule id="step1"  exclusive="false">
          <block><![CDATA[ 
                       import  com.custom.rule.*;
                       rs = new RuleSet(); 
                       rs.name="asdf";
                        rs.print();
                   ]]></block>
          </mvel-rule>
          </rule-set>
          </rules>
          rule2中可見mvel可以導入未知jar包并進行處理,確實強大,就有了足夠的靈活性. 自定義規則庫源碼及使用示例下載.
          本例依賴xstream
          1.4.9 ,mvel2.0
          自定義規則庫除了可以應用于一般系統業務處理,當然也還可以用于大數據處理。比如hadoop/spark統計用戶積分等
          如果再定義一套配置規則的UI。。。好的,業務人員可以自己設置計算規則了。






          posted on 2017-08-20 14:52 傻 瓜 閱讀(2659) 評論(0)  編輯  收藏 所屬分類: 雜項

          導航

          統計

          常用鏈接

          留言簿(7)

          我參與的團隊

          隨筆分類

          隨筆檔案

          文章分類

          友情鏈接

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 中阳县| 神池县| 微山县| 景德镇市| 陆丰市| 乃东县| 固安县| 敦化市| 上林县| 郴州市| 东台市| 穆棱市| 崇信县| 太保市| 梓潼县| 卢湾区| 五原县| 定结县| 东至县| 理塘县| 翼城县| 青海省| 青岛市| 石棉县| 视频| 无棣县| 宁远县| 汶川县| 鄂托克旗| 渝中区| 房产| 高尔夫| 九台市| 德化县| 闽清县| 万全县| 扬州市| 长阳| 凤庆县| 遵义县| 玉山县|