加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc – Asp.net MVC 3验证在TryUpdateModel中排除了一些

发布时间:2020-12-16 04:24:19 所属栏目:asp.Net 来源:网络整理
导读:我正在使用ASP.NET MVC Razor和Data Annotation验证器 我的模特: public class Person { public int id { get; set; } [Required] public string FirstName { get; set; } [Required] public string LastName { get; set; } } FirstName和LastName是Requerd
我正在使用ASP.NET MVC Razor和Data Annotation验证器
我的模特:
public class Person 
{ 
    public int id { get; set; } 

    [Required] 
    public string FirstName { get; set; } 

    [Required] 
    public string LastName { get; set; } 
}

FirstName和LastName是Requerd.
我想编辑FirstName.我的Methode是:

public ActionResult Edit([Bind(Include = "FirstName")]Person person)
{
    var p = GetPerson();
    if (TryUpdateModel(p))
    {
        //Save Changes;
    }
}

但是TryUpdateModel总是返回false.因为LastName无效.

如何防止在TryUpdateModel中检查LastName的检查?

注意:

>代码是简化的.我真正的代码很复杂
>我必须使用Requierd for Two Property
>我不想使用不同的模型类

解决方法

我找到了Nice Solution.我必须从ModelState中删除未使用的Field.然后ModelState.IsValid返回true.首先我需要Create New Attribute类:
public class ValidateOnlyIncomingValuesAttribute : ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        var modelState = filterContext.Controller.ViewData.ModelState;
        var valueProvider = filterContext.Controller.ValueProvider;

        var keysWithNoIncomingValue = modelState.Keys.Where( x=>!valueProvider.ContainsPrefix(x) );
        foreach (var key in keysWithNoIncomingValue)
            modelState[key].Errors.Clear();
    }
}

然后我在我的方法上添加属性:

[ValidateOnlyIncomingValuesAttribute]
public ActionResult Edit([Bind(Include = "FirstName")]Person person)
{
    var p = GetPerson();
    if (ModelState.IsValid)
    {
        TryUpdateModel(p);
        //Save Changes;
    }
}

看看这个:http://blog.stevensanderson.com/2010/02/19/partial-validation-in-aspnet-mvc-2/

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读