[.NET] 使用ValidationContext快速進行模型資料的驗證

来源:https://www.cnblogs.com/wwwblender-3dcn/archive/2019/01/07/10234889.html
-Advertisement-
Play Games

在進行WebAPI功能開發的時候,一般傳統的驗證資料是否合法的方式,都是透過if/else的方式進行判斷若是使用ValidationContext,就可以省去很多自行撰寫程式碼的工作 要使用ValidationContext的驗證方式很簡單,我先用一個簡單的例子來說明就可以呈現所需要的結果 1.首先 ...


在進行WebAPI功能開發的時候,一般傳統的驗證資料是否合法的方式,都是透過if/else的方式進行判斷
若是使用ValidationContext,就可以省去很多自行撰寫程式碼的工作

要使用ValidationContext的驗證方式很簡單,我先用一個簡單的例子來說明就可以呈現所需要的結果

1.首先先在專案中建立一個新的模型檔案,併在模型檔案中加入下麵的程式碼

public class ValidModels
{
    /// <summary>
    /// 輸入資料的模型
    /// </summary>
    public class ValidInfoQuery
    {
        [Required]
        public string Name { get; set; }
        public string Tel { get; set; }
        public string Address { get; set; }
        [Required]
        [Range(1, 130)]
        public int Age { get; set; }
        [Required]
        public DateTime Birthday { get; set; }
    }

    /// <summary>
    /// 回傳驗證結果的模型
    /// </summary>
    public class ValidInfoResult
    {
        public bool IsValid { get; set; }
        public List<ValidItem> List { get; set; }
        public class ValidItem
        {
            public IEnumerable<string> Field { get; set; }
            public string Message { get; set; }
        }
    }
}

  

在這個模型中,我們定義了要輸入的資料模型,以及要回傳的模型定義,在輸入的模型ValidInfoQuery中,特別在"Name"、"Age"、"Birthday"三個欄位中,加上[Required]的屬性。並且在"Age"的欄位中,加入[Range(1, 130)]的屬性,代表Age的合法值在1到130之間

2.接著加入一個新的控制器"ValidController.cs",加入一個POST的方法,並將剛剛新增的模型,分別放入Input以及Output的參數

public class ValidController : ApiController
{
    /// <summary>
    /// 執行資料寫入的Post動作
    /// </summary>
    /// <param name="query"></param>
    public Models.ValidModels.ValidInfoResult Post(Models.ValidModels.ValidInfoQuery query)
    {

    }
}

  3.一般傳統進行輸入資料驗證的方式,會採用下麵的方式進行驗證

// 傳統欄位驗證的寫法

// 驗證Name欄位
if (string.IsNullOrEmpty(query.Name))
{
    result.IsValid = false;
    result.List.Add(new Models.ValidModels.ValidInfoResult.ValidItem()
    {
        Field = new List<string> { "Name" },
        Message = "Name欄位必填"
    });
}

// 驗證Age欄位
if (query.Age > 130 || query.Age < 1)
{
    result.IsValid = false;
    result.List.Add(new Models.ValidModels.ValidInfoResult.ValidItem()
    {
        Field = new List<string> { "Age" },
        Message = "Age欄位必須在1與130之間"
    });
}

  但是這樣的寫法,一但Input模型的欄位增加的話,程式碼也會相對的增加。也會影響程式碼的效率。所以我們將驗證的方式更改一下,改為ValidationContext進行驗證

// 使用ValidationContext的驗證物件
// 定義ValidationContext的驗證物件
var context = new ValidationContext(query);

// 定義進行Validation回傳的訊息
var validationResults = new List<ValidationResult>();

// 進行驗證動作
bool isValid = Validator.TryValidateObject(query, context, validationResults, true);

// 將驗證結果進行處理,並回傳到指定的回傳物件中
result.IsValid = isValid;
result.List = validationResults.Select(c => new Models.ValidModels.ValidInfoResult.ValidItem()
                                {
                                    Field = c.MemberNames,
                                    Message = c.ErrorMessage
                                })
                                .ToList();

  

從上面的程式碼可以很清楚的看到,只要定義出一個ValidationContext物件,並將要驗證的模型資料傳入,就可以在TryValidateObject的方法中,將所有資料不合法的欄位進行驗證並得到結果

4.程式碼完成後,我們實際執行剛剛的程式內容,並透過Swagger進行資料的輸入。其中Name的欄位以及Age的欄位我刻意輸入了不合法的內容

 

按下"Try it"之後,得到的結果如下圖所示

可以看到,在結果的顯示上,很清楚的列出"Name "與"Age"兩個欄位是驗證失敗的,也顯示了為什麼發生錯誤的訊息內容

透過ValidationContext的驗證方式,除了可以很快的完成模型資料的合法性驗證外,也可以大量的減少撰寫驗證資料的程式碼,提升程式效率與開發速度

範常式式下載
https://github.com/madukapai/maduka-WebAPI


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 由於 Apache公司發現myBatis的分頁弊端,所以又研發出得補丁:PageHelper 中央倉庫5.1.2版連接地址: <!-- https://mvnrepository.com/artifact/com.github.pagehelper/pagehelper --><dependency ...
  • 變數 什麼是變數 變數就是變化的量,變就是變化,量用於衡量描述對象的狀態 為什麼要有變數 程式執行的本質就是一系列狀態的變化,變是程式執行的直接體現,所以我們需要有一種機制能夠反映或者說是保存下來程式執行時狀態以及狀態的變化。 變數的定義規範 #1.變數名只能是字母、數字或下劃線的組合 #2.變數名 ...
  • 寫在前面 從今天開始的幾篇文章,我將就國內目前比較主流的一些線上學習平臺數據進行抓取,如果時間充足的情況下,會對他們進行一些簡單的分析,好了,平臺大概有 ,`CSDN學院 網易雲課堂 慕課網 mongodb`裡面,如果對上述平臺造成了困擾,請見諒,畢竟我就抓取那麼一小會的時間,不會對伺服器有任何影響 ...
  • Django 系列博客(三) 前言 本篇博客介紹 django 的前後端交互及如何處理 get 請求和 post 請求。 get 請求 get請求是單純的請求一個頁面資源,一般不建議進行賬號信息的傳輸。 配置路由 配置視圖 配置頁面資源 post 請求 配置路由 配置視圖 配置頁面資源 前後端交互 ...
  • Kubernetes簡介 Kubernetes是Google基於Borg開源的容器編排調度引擎,作為CNCF(Cloud Native Computing Foundation)最重要的組件之一,它的目標不僅僅是一個編排系統,而是提供一個規範,可以讓你來描述集群的架構,定義服務的最終狀態,Kuber ...
  • 本文通過一張圖來看一下路由的配置以及請求處理的機制。(ASP.NET Core 系列目錄) 一、概述 路由主要有兩個主要功能: 這兩個功能看起來這兩個是相反的。 A.路由的配置 路由的兩個功能都離不開一個基本的操作:路由的基本配置。在Startup中預設通過 routes.MapRoute(name ...
  • 接下來的幾篇,我想討論下遷移桌面程式到MS Store,可以採用的比較常見、通用性比較強的實施步驟和分層架構。 通常商業項目一般都是不斷的迭代,不太可能突然停止更新現有的桌面版本,然後花很長時間從頭來寫UWP版本,所以我建議將遷移的過程分階段,通過幾個版本的迭代,慢慢地從傳統桌面程式,轉變成一個可以 ...
  • 最近有個需求就是一個抽象倉儲層介面方法需要SqlServer以及Oracle兩種實現方式,為了靈活我在依賴註入的時候把這兩種實現都給註入進了依賴註入容器中,但是在服務調用的時候總是獲取到最後註入的那個方法的實現,這時候就在想能不能實現動態的選擇使用哪種實現呢?如果可以的話那麼我只需要在配置文件中進行 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...