0

データベースのユーザー データを更新しようとしましたが、ビューから値を取得し、これらのデータを現在のユーザーに割り当てています。しかし、ユーザーのデータを更新すると、その行でエラーが発生します。Validation failed for one or morevar result = await UserManager.UpdateAsync(userAccount);と書かれています。エンティティ。詳細については、「EntityValidationErrors」プロパティを参照してください。.どうすれば修正できますか? ありがとう

コントローラ:

public ApplicationUserManager UserManager
    {
        get
        {
            return _userManager ?? HttpContext.GetOwinContext().GetUserManager<ApplicationUserManager>();
        }
        private set
        {
            _userManager = value;
        }
    }

    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> ModifyAccount(ModifyUserAccountViewModel model)
    {
        var user = await UserManager.FindByIdAsync(int.Parse(User.Identity.GetUserId()));
        UserAccount userAccount = (UserAccount)user;
        userAccount.surname = model.surname;
        userAccount.name = model.name;
        userAccount.Email = model.email;
        var result = await UserManager.UpdateAsync(userAccount);
        if (result.Succeeded)
        {
            return RedirectToAction("Index", new { Message = "Account modyfyied successfully!" });
        }
        AddErrors(result);
        return View("Error");
     }

Startup.cs:

public void Configuration(IAppBuilder app)
    {
        ConfigureAuth(app);
        app.CreatePerOwinContext<ApplicationUserManager>(ApplicationUserManager.Create);          
    }
4

1 に答える 1

0

この投稿で@Praveen Prasad が提案しているように、例外をキャッチして、どのような検証エラーがあるかを確認できます。

 [HttpPost]
 [ValidateAntiForgeryToken]
 public async Task<ActionResult> ModifyAccount(ModifyUserAccountViewModel model)
 {
    var user = await UserManager.FindByIdAsync(int.Parse(User.Identity.GetUserId()));
    UserAccount userAccount = (UserAccount)user;
    userAccount.surname = model.surname;
    userAccount.name = model.name;
    userAccount.Email = model.email;

    try { 
      var result = await UserManager.UpdateAsync(userAccount);
    }
    catch (DbEntityValidationException dbEx)
    {
        foreach (var validationErrors in dbEx.EntityValidationErrors)
        {
            foreach (var validationError in validationErrors.ValidationErrors)
            {
               Trace.TraceInformation("Property: {0} Error: {1}", 
                                validationError.PropertyName, 
                                validationError.ErrorMessage);
            }
        }
    }

    if (result.Succeeded)
    {
       return RedirectToAction("Index", new { Message = "Account modyfyied successfully!" });
    }
    AddErrors(result);
    return View("Error");
}
于 2015-09-02T13:22:52.933 に答える