亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C# 腳本引擎RulesEngine的使用詳解

 更新時間:2021年02月06日 08:33:17   作者:波多爾斯基  
這篇文章主要介紹了C# 腳本引擎RulesEngine的使用方法,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下

當(dāng)編寫應(yīng)用程序時,經(jīng)常性需要花費大量的時間與精力處理業(yè)務(wù)邏輯,往往業(yè)務(wù)邏輯的變化需要重構(gòu)或者增加大量代碼,對開發(fā)測試人員很不友好。

之前在這篇文章說過,可以使用腳本引擎來將我們需要經(jīng)常變化的代碼進行動態(tài)編譯執(zhí)行,自由度非常大,不過對應(yīng)的需要資源也多。如果只是針對非常具體業(yè)務(wù)邏輯的變化,可以嘗試使用RulesEngine對程序進行操作。

下文使用了官方示例且部分內(nèi)容翻譯自說明文檔

簡介

RulesEngine是微軟推出的規(guī)則引擎,規(guī)則引擎在很多企業(yè)開發(fā)中有所應(yīng)用,是處理經(jīng)常變動需求的一種優(yōu)雅的方法。個人任務(wù),規(guī)則引擎適用于以下的一些場景:

  • 輸入輸出類型數(shù)量比較固定,但是執(zhí)行邏輯經(jīng)常變化;
  • switch條件經(jīng)常變化,復(fù)雜switch語句的替代;
  • 會變動的,具有多種條件或者規(guī)則的業(yè)務(wù)邏輯;
  • 規(guī)則自由度不要求特別高的場景。(這種情況建議使用腳本引擎)

RulesEngine的規(guī)則使用JSON進行存儲,通過lambda表達式方式表述規(guī)則(Rules)。

安裝很方便,直接使用nuget進行安裝:

install-pacakge RulesEngine

規(guī)則定義

需要有Rules,有WorkflowName,然后還有一些屬性。

[
 {
 "WorkflowName": "Discount",
 "Rules": [
  {
  "RuleName": "GiveDiscount10",
  "SuccessEvent": "10",
  "ErrorMessage": "One or more adjust rules failed.",
  "ErrorType": "Error",
  "RuleExpressionType": "LambdaExpression",
  "Expression": "input1.country == \"india\" AND input1.loyalityFactor <= 2 AND input1.totalPurchasesToDate >= 5000 AND input2.totalOrders > 2 AND input3.noOfVisitsPerMonth > 2"
  }
 ]
 }
]

除了標(biāo)準的RuleExpressionType,還可以通過定義Rules嵌套多個條件,下面是Or邏輯。

{
"RuleName": "GiveDiscount30NestedOrExample",
"SuccessEvent": "30",
"ErrorMessage": "One or more adjust rules failed.",
"ErrorType": "Error",
"Operator": "OrElse",
"Rules":[
 {
 "RuleName": "IsLoyalAndHasGoodSpend",
 "ErrorMessage": "One or more adjust rules failed.",
 "ErrorType": "Error",
 "RuleExpressionType": "LambdaExpression",
 "Expression": "input1.loyalityFactor > 3 AND input1.totalPurchasesToDate >= 50000 AND input1.totalPurchasesToDate <= 100000"
 },
 {
 "RuleName": "OrHasHighNumberOfTotalOrders",
 "ErrorMessage": "One or more adjust rules failed.",
 "ErrorType": "Error",
 "RuleExpressionType": "LambdaExpression",
 "Expression": "input2.totalOrders > 15"
 }
]
}

示例

可以從官方的代碼庫中下載示例,定義了上述規(guī)則,就可以直接開始用了。示例描述了這么一個應(yīng)用場景:

根據(jù)不同的客戶屬性,提供不同的折扣。由于銷售的情況變化較快,提供折扣的規(guī)則也需要經(jīng)常變動。因此比較適用于規(guī)則引擎。

public void Run()
{
 Console.WriteLine($"Running {nameof(BasicDemo)}....");
 //創(chuàng)建輸入
 var basicInfo = "{\"name\": \"hello\",\"email\": \"abcy@xyz.com\",\"creditHistory\": \"good\",\"country\": \"canada\",\"loyalityFactor\": 3,\"totalPurchasesToDate\": 10000}";
 var orderInfo = "{\"totalOrders\": 5,\"recurringItems\": 2}";
 var telemetryInfo = "{\"noOfVisitsPerMonth\": 10,\"percentageOfBuyingToVisit\": 15}";

 var converter = new ExpandoObjectConverter();

 dynamic input1 = JsonConvert.DeserializeObject<ExpandoObject>(basicInfo, converter);
 dynamic input2 = JsonConvert.DeserializeObject<ExpandoObject>(orderInfo, converter);
 dynamic input3 = JsonConvert.DeserializeObject<ExpandoObject>(telemetryInfo, converter);

 var inputs = new dynamic[]
  {
   input1,
   input2,
   input3
  };
 //加載規(guī)則
 var files = Directory.GetFiles(Directory.GetCurrentDirectory(), "Discount.json", SearchOption.AllDirectories);
 if (files == null || files.Length == 0)
  throw new Exception("Rules not found.");

 var fileData = File.ReadAllText(files[0]);
 var workflowRules = JsonConvert.DeserializeObject<List<WorkflowRules>>(fileData);
 //初始化規(guī)則引擎
 var bre = new RulesEngine.RulesEngine(workflowRules.ToArray(), null);

 string discountOffered = "No discount offered.";
 //執(zhí)行規(guī)則
 List<RuleResultTree> resultList = bre.ExecuteAllRulesAsync("Discount", inputs).Result;
 //處理結(jié)果
 resultList.OnSuccess((eventName) => {
  discountOffered = $"Discount offered is {eventName} % over MRP.";
 });

 resultList.OnFail(() => {
  discountOffered = "The user is not eligible for any discount.";
 });

 Console.WriteLine(discountOffered);
}

輸入

輸入一般來說是IEnumerable<dynamic>或者是匿名類型,上面實例展示的是由json反序列化形成的dynamic類型,對于程序生成的數(shù)據(jù),使用匿名類型更加方便。

var nestedInput = new {
    SimpleProp = "simpleProp",
    NestedProp = new {
     SimpleProp = "nestedSimpleProp",
     ListProp = new List<ListItem>
     {
      new ListItem
      {
       Id = 1,
       Value = "first"
      },
      new ListItem
      {
       Id = 2,
       Value = "second"
      }
     }
    }

   };

命名空間

和腳本引擎一樣,默認規(guī)則引擎只能訪問System的命名空間。如果需要使用到稍微復(fù)雜一些的類型,可以自己定義類型或者函數(shù)。比如定義一個這樣的函數(shù):

public static class Utils
{
 public static bool CheckContains(string check, string valList)
 {
  if (String.IsNullOrEmpty(check) || String.IsNullOrEmpty(valList))
   return false;

  var list = valList.Split(',').ToList();
  return list.Contains(check);
 }
}

需要使用的時候,先將類傳遞給RulesEngine:

var reSettingsWithCustomTypes = new ReSettings { CustomTypes = new Type[] { typeof(Utils) } };
var engine = new RulesEngine.RulesEngine(workflowRules.ToArray(), null, reSettingsWithCustomTypes);

然后就可以直接在表達式中使用了。

"Expression": "Utils.CheckContains(input1.country, \"india,usa,canada,France\") == true"

規(guī)則參數(shù)

默認情況下,規(guī)則的輸入使用的是類似input1 input2這樣的形式,如果想直觀一點,可以使用RuleParameter來進行封裝具體的參數(shù)類型。

RuleParameter ruleParameter = new RuleParameter("NIP", nestedInput);
var resultList = bre.ExecuteAllRulesAsync(workflow.WorkflowName, ruleParameter).Result;

本地變量

如果表達式比較復(fù)雜的情況下,可以使用本地變量來進行分段處理,這對調(diào)試來說會比較方便。

本地變量的關(guān)鍵字為localParams,可以將中間的內(nèi)容簡單理解成var name = expression

{
  "name": "allow_access_if_all_mandatory_trainings_are_done_or_access_isSecure",
  "errorMessage": "Please complete all your training(s) to get access to this content or access it from a secure domain/location.",
  "errorType": "Error",
  "localParams": [
   {
   "name": "completedSecurityTrainings",
   "expression": "MasterSecurityComplainceTrainings.Where(Status.Equals(\"Completed\", StringComparison.InvariantCultureIgnoreCase))"
   },
   {
   "name": "completedProjectTrainings",
   "expression": "MasterProjectComplainceTrainings.Where(Status.Equals(\"Completed\", StringComparison.InvariantCultureIgnoreCase))"
   },
   {
   "name": "isRequestAccessSecured",
   "expression": "UserRequestDetails.Location.Country == \"India\" ? ((UserRequestDetails.Location.City == \"Bangalore\" && UserRequestDetails.Domain=\"xxxx\")? true : false):false"
   }
  ],
  "expression": "(completedSecurityTrainings.Any() && completedProjectTrainings.Any()) || isRequestAccessSecured "
  }

總結(jié)

使用規(guī)則引擎,可以將經(jīng)常變動的業(yè)務(wù)邏輯獨立摘出來,為我們編寫動態(tài)、可拓展的程序提供了很大的便利。RulesEngine這個東西提供的API也比較簡潔,上手非常簡單。

以上就是C# 腳本引擎RulesEngine的使用詳解的詳細內(nèi)容,更多關(guān)于C# 腳本引擎RulesEngine的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 將ocx文件轉(zhuǎn)換成C#程序引用的DLL文件的辦法

    將ocx文件轉(zhuǎn)換成C#程序引用的DLL文件的辦法

    將ocx文件轉(zhuǎn)換成C#程序引用的DLL文件的辦法,需要的朋友可以參考一下
    2013-03-03
  • C#中 const 和 readonly 的不同

    C#中 const 和 readonly 的不同

    const 和 readonly 的區(qū)別,總是不太清楚,于是查了查資料。
    2013-04-04
  • 詳解C# 虛方法virtual

    詳解C# 虛方法virtual

    這篇文章主要介紹了C# 虛方法virtual的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下
    2021-04-04
  • C#圖片添加水印的實現(xiàn)代碼

    C#圖片添加水印的實現(xiàn)代碼

    這篇文章主要為大家詳細介紹了C#給圖片添加水印的實現(xiàn)代碼,不僅可以為圖片加文字水印,還可以判斷是否是圖片文件,感興趣的小伙伴們可以參考一下
    2016-02-02
  • C# 常用日期時間函數(shù)(老用不熟)

    C# 常用日期時間函數(shù)(老用不熟)

    C# 常用日期時間函數(shù)(老用不熟) ,需要的朋友可以參考下。
    2009-09-09
  • C#多線程學(xué)習(xí)之(一)多線程的相關(guān)概念分析

    C#多線程學(xué)習(xí)之(一)多線程的相關(guān)概念分析

    這篇文章主要介紹了C#多線程學(xué)習(xí)之多線程的相關(guān)概念,涉及C#中多線程的相關(guān)概念與使用技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • c#事件使用示例詳解

    c#事件使用示例詳解

    這篇文章主要介紹了c#事件使用方法,下面我們利用一個例子來加深我們對事件的理解,需要的朋友可以參考下
    2014-04-04
  • C#結(jié)合JavaScript實現(xiàn)上傳視頻到騰訊云點播平臺的操作方法

    C#結(jié)合JavaScript實現(xiàn)上傳視頻到騰訊云點播平臺的操作方法

    這篇文章主要介紹了C#結(jié)合JavaScript實現(xiàn)上傳視頻到騰訊云點播平臺,上傳視頻功能,主要要解決兩個問題,一是在服務(wù)端通過C#生成簽名和SDKID,二是在客戶端通過JavaScript上傳視頻到騰訊云點播服務(wù)器,感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • C#使用ScrapySharp實現(xiàn)多線程下載操作

    C#使用ScrapySharp實現(xiàn)多線程下載操作

    在現(xiàn)代互聯(lián)網(wǎng)應(yīng)用中,數(shù)據(jù)抓取是一個常見的需求,無論是為了數(shù)據(jù)分析、內(nèi)容聚合還是自動化測試,ScrapySharp 是一個基于 .NET 的輕量級、高性能的網(wǎng)頁抓取庫,本文將探討如何在 C# 中使用 ScrapySharp 實現(xiàn)多線程下載策略,需要的朋友可以參考下
    2024-08-08
  • C#比較日期的方法總結(jié)

    C#比較日期的方法總結(jié)

    在本篇內(nèi)容中小編給大家整理了關(guān)于C#比較日期的方法和相關(guān)知識點,有需要的朋友們學(xué)習(xí)下。
    2019-02-02

最新評論