如何解决用于数据库验证值的ASP.NET MVC验证体系结构
|| 可以说我有一个像这样的课程public class Blog{
[Key]
public int ID{get;set;}
//these can only be tags that are in the tags db table
IEnumerable<string> Tags{get;set;}
//validation pseudocode to illustrate issue
public bool IsValid() {
//this is my issue-- how do i get my db context/repository
//into my validation logic for this class? i need it
var goodTags=db.Tags.Select(i=>i.Name);
//if this tag isn\'t a \"goodTag\",then this shouldnt validate
Tags.ForEach(i=> {
if(!goodTags.Contains(i))
return false;
});
}
}
如何在不将数据访问逻辑放入模型的情况下,验证标签中包含的字符串是否在标签数据库表中?我正在使用MVC3。你是怎么做到的?
谢谢!
解决方法
使用IInvalidatableObject进行自我验证,如下所示:
public Class Blog : IValidatableObject
{
[Key]
public int Id {get; set;}
public ICollection<string> Tags {get; set;}
public IEnumerable<ValidationResult> Validate(ValidationContext validationContext)
{
if(!Tags.Contains(\"testString\"))
{
yield return new ValidationResult(\"Not a valid tag.\",new [] {\"Tags\"});
}
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。