微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-mvc – 使用数据注释进行自定义验证

我正在使用数据注释来检查正在输入的数据,但是当涉及更多自定义方式来验证数据时,我陷入了困境.

我需要对数据库运行查询以查看是否存在存在的东西,然后在出现“自定义数据库检查错误”时向用户报告,例如“公司名称已存在”

我如何与dataannotations一起实现这样的东西?

我使用linq和3.5sp1附带的实体框架完成了所有查询

/ M

解决方法

扩展数据注释的自定义属性

您必须编写自己的属性,以对数据存储进行对象实例的验证.

确保您的类继承System.ComponentModel.DataAnnotations.ValidationAttribute类:

public class MustNotExist: ValidationAttribute
{
    ...
}

警告

当我需要验证对象在数据存储中是唯一的时候,我遇到了类似的情况.但是这种验证在实体类本身是不可能的,因为它应该只适用于那些正在创建的实体,但是当你从数据存储中返回实体时却不行.

我的解决方案是拥有一个单独的接口,类和属性.

public interface IExternalValidator ...

class DBUniqueValidator: IExternalValidator ...

class ValidateExternallyAttribute: Filterattribute,IActionFilter
{
    ...
    public ValidateExternallyAttribute(Type validatorType,Type entityType) ...
    ...
}

我能够将我的属性放在获取实体参数的控制器动作上.过滤器操作属性然后检查控制器操作参数(它可以轻松访问其类型和值)并针对正确的参数(在属性定义中提供的类型)运行外部验证器,并在验证失败时填充ModelState错误.

[ValidateExternally(typeof(DBUniqueValidator),typeof(User))]
public ActionResult RegisterUser(User newUser)
{
    if (!this.ModelState.IsValid)
    {
        // act accordingly - probably return some error depending on model state errors
    }
    // register new user in data store
}

这样我就可以仅对那些实际需要它的动作运行外部验证,这种技术也帮助我的控制器动作代码保持干净和简短.我所要做的就是检查是否存在任何模型状态错误.

原文地址:https://www.jb51.cc/aspnet/252028.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐