【问题标题】:FluentValidation unique name validation using databaseFluentValidation 使用数据库的唯一名称验证
【发布时间】:2012-11-15 21:10:43
【问题描述】:

我有 Category 模型,该模型具有 Name 字段,并且每个类别名称必须是唯一的。我已经进行了验证,当我尝试创建新类别时它可以工作,但在尝试编辑它时出现问题。现在它只是检查名称是否存在,当然当我尝试编辑同一类别时它会检查。

型号

[Validator(typeof(CategoryValidator))]
public class Category
{
    public int ID { get; set; }
    public string Name { get; set; }
    virtual public ICollection<Image> Images { get; set; }
}

public class CategoryValidator : AbstractValidator<Category>
{
    public CategoryValidator()
    {
        RuleFor(x => x.Name).NotEmpty().WithMessage("Category name is required.").Must(UniqueName).WithMessage("This category name already exists.");
    }

    private bool UniqueName(string name)
    {
        ProjecteDataContext _db = new ProjecteDataContext();
        var category = _db.Categories.Where(x => x.Name.ToLower() == name.ToLower()).SingleOrDefault();

        if (category == null) return true;
        return false;
    }
}

如您所见,我有 UniqueName(string name) 函数,但我如何传递 ID 或其中的整个模型,以便我可以检查它是否与我正在尝试编辑的模型相同的 id 然后它通过。我怎么能通过UniqueName(string name, int? id) 之类的东西?我今天才发现 FluentValidation,我不知道。

【问题讨论】:

    标签: c# asp.net asp.net-mvc asp.net-mvc-4 fluentvalidation


    【解决方案1】:

    Predicate Validator (aka Must) 有一个重载,它接受带有两个参数(已验证对象和属性值)的谓词。在您的情况下,谓词的类型为Func&lt;Category, string, bool&gt;。所以只需将Category 参数添加到您的唯一名称验证方法中:

    private bool UniqueName(Category category, string name)
    {
            ProjecteDataContext _db = new ProjecteDataContext();
            var dbCategory = _db.Categories
                                .Where(x => x.Name.ToLower() == name.ToLower())
                                .SingleOrDefault();
    
            if (dbCategory == null) 
                return true;
    
            return dbCategory.ID == category.ID;
    }
    

    【讨论】:

    • 旁注:您应该在完成后立即处理 DbContext,因此“使用 (var _db = new ProjecteDataContext())”
    • 是否可以注入DbContext?
    • @IshThomas 的简短回答是“是的,您可以将上下文注入验证器”。考虑专门搜索注入验证器,您应该找到与之相关的答案。 FluentValidation 的文档也提到了如何做到这一点。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-05-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-03-14
    相关资源
    最近更新 更多