asp.net core系列之模型绑定和验证方法 -k8凯发
一。 模型绑定asp。net core mvc 中的模型绑定,是将 http 请求中的数据映射到 action方法参数。 这些参数可能是简单类型的参数,如字符串、整数或浮点数,也可能是复杂类型的参数。 当 mvc 收到 http 请求时,它会将此请求路由定位到控制器的指定 action方法。
默认路由模板为 {controller=home}/{action=index}/{id?}//例如:请求urlhttp://contoso。com/movies/edit/2 //映射到movies/edit/2public iactionresult edit(int? id)上面url请求对应movies控制器下的edit方法,该方法接受名为 id 的可选参数。
mvc会将edit中的id参数绑定到路由值中 具有相同名称 的值。 url 路由中的字符串不区分大小写。上面示例绑定的参数是简单类型,如果参数是一个类,例如 movie 类型,该类包含简单和复杂类型作为属性,mvc的模型绑定仍然可以很好地处理它。
它使用反射和递归来遍历寻找匹配的复杂类型的属性(如:collection、dictionary)。如果模型绑定失败,mvc 不会引发错误,参数值会是null。如果http 请求中的数据是用户输入的值,在action中应使用 modelstate。
isvalid 属性检查,不需要手动去检查。注意:若要实现模型绑定,该类必须具有要绑定的公共默认构造函数和公共可写属性。发生模型绑定时,在使用公共默认构造函数对类进行实例化后才可设置属性。模型绑定完成后,将发生模型验证。 对于绝大多数开发方案,默认模型绑定效果极佳。
还可以扩展,如果有特殊需求,则可自定义内置行为包括:模型绑定特性、全局自定义模型绑定和验证、绑定请求正文中的带格式数据(json、xml 和许多其他格式)、还有高级篇中自定义模型绑定。这里不在说明,请查看文档。二。模型验证在将数据存储到数据库之前,应用程序必须先验证数据。
在 mvc 中,验证发生在客户端和服务器上。2。1 验证属性验证属性是模型验证的一种方法, 概念上类似于对数据库表中字段的验证, 验证属性在属性级别指定,下面是一个示例:public class movie{ public int id { get; set; } [required] [stringlength(100)] public string title { get; set; } [classicmovie(1960)] [datatype(datatype。
date)] public datetime releasedate { get; set; } [required] [stringlength(1000)] public string description { get; set; } [range(0, 999。
99)] public decimal price { get; set; } [required] public genre genre { get; set; } public bool preorder { get; set; }}常用的内置验证属性包括: [ creditcard] 信用卡格式、 [compare]匹配两个属性、 [ emailaddress] 邮件格式、 [ phone] 电话格式、 [range] 给定范围内、 [regularexpression] 正则表达式、 [required]必须属性值、 [stringlength] 最大长度、 [url] url格式,还可以包括自定义验证属性(例如 classicmovie )。
所有的内置验证属性 参考凯发k8国际手机app下载官网2。2 自定义验证上面的验证属性适用于大多数验证需求。但是,某些验证规则特定于你的业务。在 mvc 中创建自定义验证属性很简单。只需从 validationattribute 继承并重写 isvalid 方法。 isvalid 方法采用两个参数,第一个是名为value的对象,第二个是名为validationcontext的 validationcontext 对象。
value引用自定义验证程序要验证的字段中的实际值。///
objectinstance; //用户不能将 1960 年以后发行的电影的流派设置为 classic if (movie。genre == “classic” && movie。releasedate。year > _year) { return new validationresult(geterrormessage()); } return validationresult。
success; } private string geterrormessage() { return $”classic movies must have a release year earlier than {_year}。”; } }运行程序,releasedate是1989年,genre是classic,点击save,验证是在服务端进行,显示错误消息,没有经过前端js验证,如下所示:2。
3 客户端js验证介绍jquery 非介入式验证脚本是一个自定义微软前端库,建立在流行的 jquery validate 插件。客户端验证原理是: mvc 的标记帮助程序和 html 帮助程序则能够使用模型属性中的验证特性和类型元数据,呈现需要验证的表单元素中的 html 5 data- 属性。
mvc 为内置模型属性和自定义模型属性生成 data- 属性。然后,jquery 非介入式验证分析 data- 属性并将逻辑传递给 jquery validate,从而将服务器端验证逻辑有效地“复制”到客户端。可以使用相关标记帮助程序在客户端上显示验证错误。
下面示例表单中,asp- 标记帮助程序代码如下: