1

在我的 MVC 应用程序中,电子邮件验证在本地工作得很好,但是当我发布和部署到服务器时它不起作用。我比较了本地和部署文件的html源,没有区别。我的 Razor 视图标记是

 <li>
        <p><strong>Email: </strong>@Model.CurrentEmailAddress <span class="deliverychange" onclick="showHidden('emailchange');">(Change email)</span></p>
        <div id="emailchange" class="fullborder" style="display: none;">
            <div class="orderrow newemailaddress">
                @Html.LabelFor(m => m.UpdatedEmailAddress)
                @Html.TextBoxFor(m => m.UpdatedEmailAddress, new { @onkeypress = "showEmailChangeConfirmation();" })
                @Html.ValidationMessageFor(m => m.UpdatedEmailAddress)
            </div>

            <div id="updatedemailkeypress" style="display: none;">
                <div class="orderrow checkboxrow emailchangeconfirm">
                    @Html.LabelFor(m => m.UpdateEmailAddress)
                    @Html.EnumRadioButtonFor(m => m.UpdateEmailAddress, false)
                </div>
            </div>

            <div class="clear">&nbsp;</div>
        </div>
    </li>

我的模型是

    [DataType(DataType.EmailAddress)]
    [RegularExpression(@"^([\w.-]+)@([\w-]+)((.(\w){2,3})+)$", ErrorMessage = "Email is not valid")]
    [Display(Name = "Enter new email address: ")]
    public string UpdatedEmailAddress { get; set; }


    [Display(Name = "We will use ****")]
    public YesNo UpdateEmailAddress { get; set; }
4

4 回答 4

2

请改用电子邮件地址属性

http://msdn.microsoft.com/en-us/library/system.componentmodel.dataannotations.emailaddressattribute%28v=vs.110%29.aspx

于 2013-10-31T13:08:04.670 回答
1

请重新检查表单标签是否存在。

表单验证实际上是通过验证表单有效方法来工作的。因此,表单必须存在。

希望这可以帮助。

于 2013-10-31T13:30:22.053 回答
1

在花了很多时间之后,我发现发布向导没有将 jquery.validate-vsdoc.js 复制到脚本文件夹。我手动将其复制到服务器并开始工作。

于 2013-11-13T13:03:49.137 回答
0

尝试使用 dataannotationsextensions 库,可以从 nuget 下载。

并像这样将电子邮件属性添加到您的模型中

using DataAnnotationsExtensions;
        [Required]
        [DataType(DataType.EmailAddress)]
        [Email]
        public string UpdatedEmailAddress { get; set; }
于 2013-10-31T13:16:42.340 回答