2016-04-22 59 views
1

我正在使用WebMatrix中已有的PasswordReset表单。我没有改变模块中的任何东西,但它不起作用。当我点击“您忘记了密码?”链接,它将我带到忘记密码表单。在我输入我的电子邮件地址并点击“发送说明”后,它会发送到我的电子邮件。但是,当我点击它提供的链接时,我立即得到了密码重置屏幕,但是他屏幕顶部显示“无法重置密码,请更正错误并重试。”尽管如此,无论如何,我尝试重置我的密码没有任何反应。PasswordReset在WebMatrix中不起作用

下面是密码重置代码:

@* Remove this section if you are using bundling *@ 
@section Scripts { 
    <script src="~/Scripts/jquery.validate.min.js"></script> 
    <script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script> 
} 

@{ 
    Layout = "~/_SiteLayout.cshtml"; 
    Page.Title = "Password Reset"; 

    var passwordResetToken = Request.Form["resetToken"] ?? Request.QueryString["resetToken"]; 

    bool tokenExpired = false; 
    bool isSuccess = false; 

    // Setup validation 
    Validation.RequireField("newPassword", "The new password field is required."); 
    Validation.Add("confirmPassword", 
     Validator.EqualsTo("newPassword", "The new password and confirmation password do not match.")); 
    Validation.RequireField("passwordResetToken", "The password reset token field is required."); 
    Validation.Add("newPassword", 
     Validator.StringLength(
      maxLength: Int32.MaxValue, 
      minLength: 6, 
      errorMessage: "New password must be at least 6 characters")); 

    if (IsPost && Validation.IsValid()) { 
     AntiForgery.Validate(); 
     var newPassword = Request["newPassword"]; 
     var confirmPassword = Request["confirmPassword"]; 

     if (WebSecurity.ResetPassword(passwordResetToken, newPassword)) { 
      isSuccess = true; 
     } else { 
      ModelState.AddError("passwordResetToken", "The password reset token is invalid."); 
      tokenExpired = true; 
     } 
    } 
} 

<hgroup class="title"> 
    <h1>@Page.Title.</h1> 
    <h2>Use the form below to reset your password.</h2> 
</hgroup> 

@if (!WebMail.SmtpServer.IsEmpty()) { 
    if (!Validation.IsValid()) { 
     <p class="validation-summary-errors"> 
      @if (tokenExpired) { 
       <text>The password reset token is incorrect or may be expired. Visit the <a href="~/Account/ForgotPassword">forgot password page</a> 
       to generate a new one.</text> 
      } else { 
       <text>Could not reset password. Please correct the errors and try again.</text> 
      } 
     </p> 
    } 

    if (isSuccess) { 
     <p class="message-success"> 
      Password changed! Click <a href="~/Account/Login" title="Log in">here</a> to log in. 
     </p> 
    } 

    <form method="post"> 
     @AntiForgery.GetHtml() 
     <fieldset> 
      <legend>Password Change Form</legend> 
      <ol> 
       <li class="new-password"> 
        <label for="newPassword" @if (!ModelState.IsValidField("newPassword")) {<text>class="error-label"</text>}>New password</label> 
        <input type="password" id="newPassword" name="newPassword" disabled="@isSuccess" @Validation.For("newPassword") /> 
        @Html.ValidationMessage("newPassword") 
       </li> 
       <li class="confirm-password"> 
        <label for="confirmPassword" @if (!ModelState.IsValidField("confirmPassword")) {<text>class="error-label"</text>}>Confirm password</label> 
        <input type="password" id="confirmPassword" name="confirmPassword" disabled="@isSuccess" @Validation.For("confirmPassword") /> 
        @Html.ValidationMessage("confirmPassword") 
       </li> 
       <li class="reset-token"> 
        <label for="resetToken" @if (!ModelState.IsValidField("resetToken")) {<text>class="error-label"</text>}>Password reset token</label> 
        <input type="text" id="resetToken" name="resetToken" value="@passwordResetToken" disabled="@isSuccess" @Validation.For("resetToken") /> 
        @Html.ValidationMessage("resetToken") 
       </li> 
      </ol> 
      <input type="submit" value="Reset password" disabled="@isSuccess"/> 
     </fieldset> 
    </form> 
} else { 
    <p class="message-info"> 
     Password recovery is disabled for this website because the SMTP server is 
     not configured correctly. Please contact the owner of this site to reset 
     your password. 
    </p> 
} 

这里是我的_AppStart代码:

WebSecurity.InitializeDatabaseConnection( “StarterSite”, “用户配置”, “用户ID”, “电子邮件”, autoCreateTables:true);

OAuthWebSecurity.RegisterGoogleClient(); 

WebMail.SmtpServer = "smtp.gmail.com"; 
WebMail.EnableSsl = true; 

WebMail.SmtpPort = 587; 
WebMail.UserName = "[email protected]"; 
WebMail.Password = "September"; 
WebMail.From = "[email protected]"; 

回答

0

更改用户对象的常量。从那里删除必需的属性。也。我建议编写自己的基本身份验证。

+0

这是什么意思?我没跟着你。 – tnbumbray

+0

你好,我没有太多时间。 WebMatrix是一个轻量级认证框架,它在使用时具有一定的稳定性。其中之一是查看chtml属性。在那里你可以看到验证规则删除它们,你的错误将会消失。而且我也和WebMatrix一起工作了很长时间,还有很多其他的consistancies在这里,我写了我自己的框架,我建议你这样做。最好的祝福 – dewelloper