在其他地方工作的远程验证

时间:2015-08-28 14:33:52

标签: asp.net-mvc asp.net-mvc-4 razor

我有一个用户注册页面,我在其中实现了用户名的远程验证概念。我基本上想要保持每个用户名的唯一值。我能够实现它,但现在在登录页面中,当我输入用户名时,它会提示一条消息,说明用户名不可用。这仅适用于注册页面而非登录页面。有人可以解释我在做什么错误。我有一个Model User,它有一个Username属性;我正在使用远程验证。我有一个名为UserNameExsists的Action方法,它被触发进行远程验证。以及用于验证的注册视图。但是,登录页面也会触发验证。有没有办法可以为注册视图设置它?

型号:

public class User
{
    public int ID { get; set; }
    [Required]
    [Remote("UserNameExists","User",ErrorMessage="Username not available")]
    [Display(Name="User Name")]
    public string UserName { get; set; }
    [Required]
    [DataType(DataType.Password)]
    public string Password { get; set; }
    [Required]
    [Display(Name="First Name")]
    public string FirstName { get; set; }
    [Required]
    [Display(Name="Last Name")]
    public string LastName { get; set; }
    [Required]
    [DataType(DataType.PhoneNumber)]
    [MinLength(10)]
    [MaxLength(10)]
    [Display(Name="Mobile No")]
    public string PhoneNum { get; set; }
}

控制器:(名称为用户)

    //Remote Validation
    public JsonResult UserNameExists(string username)
    {
        bool user = db.Users.Any(p => p.UserName == username) ? false : true;
        return Json(user,JsonRequestBehavior.AllowGet);

    }

查看:

注册页面视图

@model HindiMovie.Models.User

@{
ViewBag.Title = "Register";
}
<link href="~/Content/Site.css" rel="stylesheet" />
<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>

<h2>Register</h2>

@using (Html.BeginForm()) {
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)

<fieldset>
    <legend>User</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.UserName)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.UserName)
        @Html.ValidationMessageFor(model => model.UserName)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.Password)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.Password)
        @Html.ValidationMessageFor(model => model.Password)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.FirstName)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.FirstName)
        @Html.ValidationMessageFor(model => model.FirstName)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.LastName)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.LastName)
        @Html.ValidationMessageFor(model => model.LastName)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.PhoneNum)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.PhoneNum)
        @Html.ValidationMessageFor(model => model.PhoneNum)
    </div>

    <p>
        <input type="submit" value="Register" />
        <input type="reset" value="Clear" />
    </p>
</fieldset>
}

@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}

登录页面查看:

@model HindiMovie.Models.User
@{
ViewBag.Title = "Login";
}

<h2>Login</h2>

@using (Html.BeginForm()) {
@Html.AntiForgeryToken()


<fieldset>
    <legend>User</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.UserName)
    </div>
    <div class="editor-field">
        @Html.TextBoxFor(model => model.UserName)
        @Html.ValidationMessageFor(model => model.UserName)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.Password)
    </div>
    <div class="editor-field">
        @Html.PasswordFor(model => model.Password)
        @Html.ValidationMessageFor(model => model.Password)
    </div>





    <p>
        <input type="submit" value="Sign in" />
    </p>
</fieldset>


}

@Html.ValidationMessage("LogOnError")

<div>
@Html.ActionLink("Create account", "Register","User")
</div>

@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}

1 个答案:

答案 0 :(得分:1)

您在“登录”和“注册”页面使用相同的模型,因此您可以在两个页面上获得相同的验证。

为每个视图创建一个ViewModel,并将验证属性放在那里。 这样,您就可以区分每个页面的验证。