我們的業務系統涉及較多的表單編輯與校驗,最簡單的方法是使用asp.net自帶的資料校驗控制項即可,但這樣有以下3個問題:
1 校驗控制項要在設計時加入表單上,並手動設定:資料類型,錯誤訊息等屬性,比較繁瑣。
2 對於一個輸入框,我們可能要檢查多項,如:必填,必須是日期格式,並且大於2007-1-1。這樣就需要加入多個校驗控制項。
3 業務規則和表單綁定在一起,不利於維護和重複使用。
我們希望的校驗功能是:
1 校驗規則和表單脫離,表單上畫好輸入框即可,校驗控制項會在執行時,根據設定檔動態建立。
2 根據驗證規則,產生預設的:不能為空,錯誤的數字類型,必須在1到100之間這樣的提示訊息。
3 彈性的驗證規則表達式:如: range(1, 200) , >=0.5 , Mail(), Mobile()。目前不
支援
and, or 這樣的條件,但容易擴展。為此我們封裝了這部分的功能,使用時只要:
在xml檔中設定好:控制項名稱,資料類型,是否必填,驗證表達式資訊。
以下是引用片段:
<ValidateInfo>
<ControlName>排口數量</ControlName>
<DataType>Integer</DataType>
<Require>true</Require>
<Expression>range(1, 100)</Expression>
</ValidateInfo>
在page的Page_Init事件中,呼叫類別方法:
ValidateHelper.LoadFromFile("資料校驗_配置.xml") 即可。
類設計:
// 配置資訊類
class ValidateInfo
{
public string ControlName;
public ValidationDataType DataType;
public string ErrorMessage;
public bool Require;
public string Expression;
}
// 校驗控制項建立工廠
public class ValidatorFactory
{
CreateRequiredFieldValidator();
CreateDateTypeCheckValidator();
CreateRangeValidator(string min, string max);
CreateCompareValidator(ValidationCompareOperator oper, string valueToCompare);
…
}
// 校驗規則解析器,根據配置訊息,建立校驗控件
public class ValidatorParser
{
Parse(ValidateInfo info, ValidatorFactory factory);
…
}
// 讀取組態訊息,並綁定校驗控製到表單
public class ValidateHelper
{
LoadFromFile(Page page, string fileName)
}