栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

属性为[Required]并且可为空意味着什么?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

属性为[Required]并且可为空意味着什么?

使属性为可空并标记有

[Required]
属性的原因是为了防止发布不足攻击。它还允许您在视图中显示初始空值,而不是属性的默认值。通常,这是通过视图模型中的值类型属性完成的。

发布不足攻击是恶意用户修改请求以忽略请求中的属性值的情况。如果该属性为

DateTime
(不能为null),则
DefaultModelBinder
它将初始化其默认值(
01/01/0001
),并且不会
ModelState
产生任何错误。结果,该值可能会被保存,即使它不是您期望的值。

如果该属性是

DateTime?
(nullable)和
[Required]
,则如果恶意用户确实在请求中省略了该属性,则将
ModelState
生成错误,因为请求中应有一个值,并且将返回视图,因此无效数据将不会被保存。

另请参见Brad Wilson的文章ASP.NET
MVC中的输入验证与模型验证
以及标题为 “发布不足” 的部分。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/402899.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号