1

当该字段没有值并且它在数据库中不可为空时,我收到 TryUpdateModel 错误。如果我将数据库中的字段更改为可为空,它就可以工作。任何人都知道一个解决方法来让它与不可为空的字段一起工作?我是 MVC 的新手,所以我只是在玩一个教程来尝试理解它....

        [AcceptVerbs(HttpVerbs.Post)]
    public ActionResult Add(FormCollection form)
    {
        var movieToAdd = new Movies();

        if (Request != null && Request.Form != null && Request.Form.HasKeys() && ValueProvider == null)
        {
            ValueProvider = new FormCollection(Request.Form).ToValueProvider();
        }

        //Deserialize (Include white list!)
        TryUpdateModel(movieToAdd, new string[] { "Title", "Director" }, form.ToValueProvider());

        // Validate
        if (string.IsNullOrEmpty(movieToAdd.Title))
            ModelState.AddModelError("Title", "Title is required!");
        if (string.IsNullOrEmpty(movieToAdd.Director))
            ModelState.AddModelError("Director", "Director is required!");

        // If valid, save movie to database
        if (ModelState.IsValid)
        {
            _db.AddToMovies1(movieToAdd);
            _db.SaveChanges();
            return RedirectToAction("Index");
        }

        // Otherwise, reshow form
        return View(movieToAdd);
    }
4

1 回答 1

0

有几件事我会改变。

  1. 修改您的方法签名以接受您ActionResult期望的强类型模型。从那里您可以检查模型是否有效并继续保存到数据库

  2. 使用强类型模型和数据注释来验证您的模型

例如:

创建一个模型,您将用于表单获取和发布操作:

public class YourModel
{

    [Required]
    public string Title {get; set;]

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

}

您的 Post ActionResult 然后变为:

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Add(YourModel postedform)
{
    // If valid, save movie to database
    if (ModelState.IsValid)
    {
        _db.AddToMovies1(postedform);
        _db.SaveChanges();
        return RedirectToAction("Index");
    }

    // Otherwise, reshow form
    return View(postedform);
}
于 2012-05-30T18:34:06.130 回答