?ASP.NET Core 模型驗證過濾器的兩種實現(xiàn)方法
在.Net Core的時代中,框架會幫你自動驗證model的state,也就是ModelState??蚣軙槟阕詣幼訫odelStateInvalidFilter,這個會運行在OnActionExecuting事件里面。
基于現(xiàn)有框架的代碼編寫的話,所以我們不再需要在業(yè)務(wù)中耦合這樣的模型判斷代碼,系統(tǒng)內(nèi)部會檢查ModelState是否為Valid,如果為InValid會直接返回400 BadRequest,這樣就沒有必要執(zhí)行后面的代碼,提高效率。因此,操作方法中不再需要以下代碼:
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
第一種方法:.Net Core 禁用模型驗證過濾器
services.Configure<ApiBehaviorOptions>(options => options.SuppressModelStateInvalidFilter = true);
SuppressModelStateInvalidFilter =true時,會關(guān)閉默認模型驗證過濾器。[ApiController] 默認自帶有400模型驗證,且優(yōu)先級比較高,如果需要自定義模型驗證,則需要先關(guān)閉默認的模型驗證。
第二種方法:自動替換默認模型驗證
//參數(shù)驗證
services.Configure<ApiBehaviorOptions>(options =>
{
options.InvalidModelStateResponseFactory = (context) =>
{
var error = context.ModelState.GetValidationSummary();
return new JsonResult(Result.FromError($"參數(shù)驗證不通過:{error.ToString()}", ResultCode.InvalidParams));
};
});
到此這篇關(guān)于 ASP.NET Core 模型驗證過濾器的兩種實現(xiàn)方法的文章就介紹到這了,更多相關(guān) ASP.NET Core 模型驗證過濾器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
asp.net DropDownList 三級聯(lián)動下拉菜單實現(xiàn)代碼
asp.net DropDownList 三級聯(lián)動下拉菜單效果代碼,需要的朋友可以參考下。2009-12-12
VB.net 查詢獲取數(shù)據(jù)庫數(shù)據(jù)信息
VB.net 查詢獲取數(shù)據(jù)庫數(shù)據(jù)信息實現(xiàn)函數(shù),需要的朋友可以參考下,代碼比較簡單。2009-07-07
使用最小?WEB?API?實現(xiàn)文件上傳的Swagger支持
這篇文章主要介紹了使用最小?WEB?API?實現(xiàn)文件上傳Swagger支持,我們使用最小?WEB?API?實現(xiàn)文件上傳功能,雖然客戶端訪問是正常的,但是當(dāng)打開?Swagger?頁面時,沒法使用?Swagger?頁面測試,下面就來一篇支持Swagger的,需要的小伙伴可以參考一下2022-02-02
無法將函數(shù)定義與現(xiàn)有的聲明匹配 問題的解決辦法 分享
無法將函數(shù)定義與現(xiàn)有的聲明匹配 問題的解決辦法 分享,需要的朋友可以參考一下2013-05-05
asp.net Execl的添加,更新操作實現(xiàn)代碼
asp.net Execl的添加、修改等實現(xiàn)代碼。2009-02-02

