WebApiClient的接口輸入驗(yàn)證方法
1. 文章目的
隨著 WebApiClient 的不斷完善,越來(lái)越多開(kāi)發(fā)者選擇WebApiClient替換原生的HttpClient,本文將介紹WebApiClient的接口參數(shù)輸入有效性驗(yàn)證的新特性。
2.DataAnnotations介紹
在 asp.net mvc
服務(wù)端編程中,我們?cè)趧?chuàng)建模型的時(shí)候,使用System.ComponentModel.DataAnnotations相關(guān)的驗(yàn)證特性,配合mvc框架,可以做前端和后端雙向輸入驗(yàn)證的效果。
public class UserInfo { [Required] [StringLength(10, MinimumLength = 1)] public string Account { get; set; } [Required] [StringLength(10, MinimumLength = 6)] public string Password { get; set; } }
以上的Required就是驗(yàn)證特性, asp.net mvc 在模型綁定的時(shí)候,會(huì)進(jìn)行驗(yàn)證一遍,驗(yàn)證結(jié)果放在控制器的ModelState屬性里面。當(dāng)然System.ComponentModel.DataAnnotations并不是 asp.net mvc 特有的,而是基礎(chǔ)庫(kù)自帶的,也就是說(shuō)任何框架下都是可以使用的。
3. 接口參數(shù)值的輸入驗(yàn)證
Validator靜態(tài)類提ValidateObject相關(guān)的方法,用于驗(yàn)證實(shí)例和實(shí)例的屬性值,WebApiClient使用Validator類來(lái)完成接口方法的參數(shù)值輸入驗(yàn)證:
/// <summary> /// 提供參數(shù)值和參數(shù)的屬性值輸入合法性驗(yàn)證 /// </summary> static class ParameterValidator { /// <summary> /// 類型的屬性否需要驗(yàn)證緩存 /// </summary> private static readonly ConcurrentCache<Type, bool> cache = new ConcurrentCache<Type, bool>(); /// <summary> /// 返回是否需要進(jìn)行屬性驗(yàn)證 /// </summary> /// <param name="instance">實(shí)例</param> /// <returns></returns> private static bool IsNeedValidateProperty(object instance) { if (instance == null) { return false; } var type = instance.GetType(); if (type == typeof(string) || type.GetTypeInfo().IsValueType == true) { return false; } return cache.GetOrAdd(type, t => t.GetProperties().Any(p => p.CanRead && p.IsDefined(typeof(ValidationAttribute), true))); } /// <summary> /// 驗(yàn)證參數(shù)值輸入合法性 /// 驗(yàn)證參數(shù)的屬性值輸入合法性 /// </summary> /// <param name="parameter">參數(shù)描述</param> /// <param name="validateProperty">是否驗(yàn)證屬性值</param> /// <exception cref="ValidationException"></exception> public static void Validate(ApiParameterDescriptor parameter, bool validateProperty) { var name = parameter.Name; var instance = parameter.Value; foreach (var validation in parameter.ValidationAttributes) { validation.Validate(instance, name); } if (validateProperty == true && IsNeedValidateProperty(instance) == true) { var ctx = new ValidationContext(instance) { MemberName = name }; Validator.ValidateObject(instance, ctx, true); } } }
4.接口參數(shù)的DataAnnotations聲明
4.1 聲明參數(shù)值的驗(yàn)證
例如GetByIdAsync方法有個(gè)id的參數(shù),服務(wù)器要求必填且最大長(zhǎng)度為10的字符串,我們可以使用Required, StringLength(10)特性修飾id這個(gè)參數(shù),在接口調(diào)用時(shí),WebApiClient會(huì)對(duì)id值進(jìn)行驗(yàn)證,如果不通過(guò)則拋出ValidationException的異常。
// /GET webapi/user/GetById?id=id001 // Return HttpResponseMessage [HttpGet("webapi/user/GetById/{id}")] [BasicAuth("userName", "password")] ITask<HttpResponseMessage> GetByIdAsync( [Required, StringLength(10)] string id);
4.2 聲明參數(shù)值的屬性驗(yàn)證
對(duì)于自定義的模型類型,只要在屬性里聲明了相關(guān)的DataAnnotations,WebApiClient就自動(dòng)進(jìn)行屬性的輸入驗(yàn)證。
public class UserInfo { [Required] [StringLength(10, MinimumLength = 1)] public string Account { get; set; } [Required] [StringLength(10, MinimumLength = 6)] public string Password { get; set; } } // POST webapi/user/UpdateWithJson // Body {"Account":"laojiu","Password":"123456"} // Return json或xml內(nèi)容 [HttpPost("webapi/user/UpdateWithJson")] ITask<UserInfo> UpdateWithJsonAsync( [JsonContent("yyyy-MM-dd HH:mm:ss")] UserInfo user);
當(dāng)user參數(shù)不為null的情況,就會(huì)驗(yàn)證它的Account和Password兩個(gè)屬性。
4.3 聲明參數(shù)值、參數(shù)的屬性值同時(shí)驗(yàn)證
對(duì)于4.2的例子,如果我們希望user參數(shù)值也不能為null,可以如下聲明方法:
// POST webapi/user/UpdateWithJson // Body {"Account":"laojiu","Password":"123456"} // Return json或xml內(nèi)容 [HttpPost("webapi/user/UpdateWithJson")] ITask<UserInfo> UpdateWithJsonAsync( [Required][JsonContent("yyyy-MM-dd HH:mm:ss")] UserInfo user);
5. 禁用參數(shù)的屬性驗(yàn)證
如果你的模型的屬性已聲明驗(yàn)證特性,但不希望WebApiClient進(jìn)行屬性值驗(yàn)證,可以在創(chuàng)建接口實(shí)例的時(shí)候,在配置項(xiàng)里禁用屬性驗(yàn)證:
var config = new HttpApiConfig { UseParameterPropertyValidate = false }; var client = HttpApiClient.Create<IUserApi>(config);
6. 結(jié)束語(yǔ)
博主為WebApiClient庫(kù)的作者,本文向讀者介紹了DataAnnotations驗(yàn)證特性在WebApiCiient下的使用方法,歡迎大家給WebApiClient提建議。 也希望大家多多支持腳本之家。
相關(guān)文章
asp.net利用ashx文件實(shí)現(xiàn)文件的上傳功能
這篇文章主要介紹了asp.net利用ashx文件實(shí)現(xiàn)文件的上傳功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11ASP.NET?MVC5網(wǎng)站開(kāi)發(fā)之添加、刪除、重置密碼、修改密碼、列表瀏覽管理員篇2(六)
這篇文章主要為大家詳細(xì)介紹了ASP.NET?MVC5網(wǎng)站開(kāi)發(fā)之添加、刪除、重置密碼、修改密碼、列表瀏覽,感興趣的小伙伴們可以參考一下2016-08-08asp.net core 集成swagger ui的原理解析
本文主要講解了如何對(duì)API進(jìn)行分組,這里僅僅是舉了一個(gè)按照API功能進(jìn)行分組的例子,其實(shí)在實(shí)際開(kāi)發(fā)中,要按照何種方式分組,可以按照需求靈活定義,比如按照API版本進(jìn)行分組2021-10-10解決.net項(xiàng)目中上傳的圖片或者文件太大無(wú)法上傳問(wèn)題
本文主要介紹了解決.net項(xiàng)目中上傳的圖片或者文件太大無(wú)法上傳問(wèn)題的具有方法,具有很好的參考價(jià)值,有需要的朋友可以看下2016-12-12asp net core 2.1中如何使用jwt(從原理到精通)
這篇文章主要給大家介紹了關(guān)于asp net core 2.1中如何使用jwt(從原理到精通)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧2018-11-11ASP.NET中TextBox使用Ajax控件顯示日期不全的問(wèn)題解決方法
這篇文章介紹了ASP.NET中TextBox使用Ajax控件顯示日期不全的問(wèn)題解決方法,有需要的朋友可以參考一下2013-10-10Asp.net 無(wú)限級(jí)分類實(shí)例代碼
近期做的一個(gè)網(wǎng)站需要一個(gè)無(wú)限級(jí)下拉列表的無(wú)限級(jí)分級(jí)功能,于是就有了下面的小作品。 開(kāi)始以為無(wú)限級(jí)下拉列表功能應(yīng)該很簡(jiǎn)單,無(wú)非就是用一個(gè)遞歸算法就好啦,但是在做起來(lái)的時(shí)候卻會(huì)遇到一些比較模糊的東西。2008-07-07ASP.NET Core擴(kuò)展庫(kù)之Http請(qǐng)求模擬功能的使用
這篇文章主要介紹了ASP.NET Core擴(kuò)展庫(kù)之Http請(qǐng)求模擬功能的使用方法,幫助大家更好的理解和學(xué)習(xí)使用.net技術(shù),感興趣的朋友可以了解下2021-04-04