首页 > 解决方案 > Asp.Net Core:如何正确地将数据从视图传递到控制器?

问题描述

我正在尝试使用视图模型将一些数据从视图传递到控制器。

鉴于我有类似的东西:

@model LoginRegisterViewModel
<input type="text" name="Email" id="Email" placeholder="Email">
<input type="password" class="form-control" name="Password" id="Password" placeholder="Password">

查看型号:

 public class LoginModel
    {
        [DataType(DataType.EmailAddress)]
        public string Email { get; set; }

        [DataType(DataType.Password)]
        public string Password { get; set; }

        [Display(Name = "Remember Me")]
        public bool RememberMe { get; set; }
        public string ReturnUrl { get; set; }
    }

    public class RegisterModel
    {
        public string Username { get; set; }

        [DataType(DataType.EmailAddress)]
        public string Email { get; set; }

        [DataType(DataType.Password)]
        public string Password { get; set; }

        public string ReturnUrl { get; set; }
    }

    public class ResetModel
    {

        [DataType(DataType.EmailAddress)]
        public string Email { get; set; }
        public string ReturnUrl { get; set; }

    }

    public class LoginRegisterViewModel
    {
        public LoginModel Login { get; set; }
        public RegisterModel Register { get; set; }
        public ResetModel Reset { get; set; }
    }

在控制器中:

 public async Task<IActionResult> Login(LoginRegisterViewModel model, string returnUrl = null)
        {
            returnUrl = returnUrl ?? Url.Content("~/");

            if (ModelState.IsValid)
            {                
                var userOrEmail = model.Login.Email;

               SignInResult result;

                if (userOrEmail.IndexOf('@') > 0)
                    result = await _signInManager.PasswordEmailSignInAsync(userOrEmail, model.Login.Password, model.Login.RememberMe, false);
                else

                result = await _signInManager.PasswordSignInAsync(userOrEmail, model.Login.Password, model.Login.RememberMe, lockoutOnFailure: false);
                if (result.Succeeded)
                {
                    return LocalRedirect(returnUrl);
                }

                else
                {
                    ModelState.AddModelError(string.Empty, "Invalid login attempt.");
                    return View(model);
                }
            }

            return View(model);
        }

我做错了,因为我收到以下错误:NullReferenceException:对象引用未设置为对象的实例。引用这一行: var userOrEmail = model.Login.Email;

标签: asp.net-core-2.0

解决方案


您绑定到错误的属性。

控制器操作需要一个类型的对象,LoginRegisterViewModel,它是您的视图期望的模型类型,但是您的控件绑定到错误的属性。

例如,<input type="text" name="Email" id="Email" placeholder="Email">这映射到 model.Email(其中 model 是 LoginRegisterViewModel 的对象),并且LoginRegisterViewModel没有Email属性,但它具有LoginModel具有 Email 属性的属性,因此您应该将输入绑定到model.Login.Email.

Ps : 你可以使用 MVC 核心标签助手将属性绑定到模型

<input asp-for="model.Login.Email" name="anyothername" class="form-control" />

甚至剃刀语法 @Html.EditorFor(model => model.Login.Email)


推荐阅读