ASP.NET MVC4 でパスワードを忘れた場合の機能を実装していますが、ユーザーがパスワードをリセットすることを許可できません。
私の MVC アプリケーションは、パスワードを忘れたユーザーのログイン ページに RECOVER password リンクを表示します。アプリケーションの最初の部分は正常に動作し、メールがユーザーに送信されます ...しかし、後の部分では、ユーザーがパスワードを変更できるようにします動かない 。
これは、パスワードを忘れたコントローラーのアクション メソッドです。
[AllowAnonymous]
public ActionResult ForgotPassword()
{
return View();
}
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult ForgotPassword(string UserName)
{
//Check user existence
var user = Membership.GetUser(UserName);
if (user == null)
{
TempData["Message"] = "User Not exist.";
}
else
{
//Generate password token
var token = WebSecurity.GeneratePasswordResetToken(UserName);
//Create URL with above token
var resetLink = "<a href='" + Url.Action("ResetPassword", "Account", new { un = UserName, rt = token }, "http") + "'>Reset Password</a>";
//Get user emailid
UsersContext db = new UsersContext();
var emailid = (from i in db.UserProfiles
where i.UserName == UserName
select i.EmailId).FirstOrDefault();
//Send mail
string subject = "Password Reset Token";
string body = "<b>Please find the Password Reset Token</b><br/>" + resetLink;
//Edit it
try
{
SendEMail(emailid, subject, body);
TempData["Message"] = "Mail Sent.";
}
catch (Exception ex)
{
TempData["Message"] = "Error occured while sending email." + ex.Message;
}
}
return View();
}
これは私のパスワードを忘れたビューです:
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<fieldset>
<legend>Forgot Password Form</legend>
<ol>
<li>
@Html.Label("User Name", new { @for = "UserName" })
@Html.TextBox("UserName")
<span style="color:red;">@TempData["Message"]</span>
</li>
</ol>
<input type="submit" value="Recover" />
</fieldset>
}
パスワードを忘れた場合の表示ページでは、ユーザーは自分のユーザー名を入力できます。ユーザー名と電子メール ID を取得して URL を作成し、ユーザーにメールを送信します。この部分は正常に実行されます。これで、ユーザーはパスワードのリセット ページにリダイレクトされます。ここでは、ユーザーが新しいパスワードを入力してデータベースを更新できるようにしたいと考えています。コントローラーのリセット アクションとビュー ページはどのようにすべきですか?
次のコントローラーアクションを使用して古いパスワードを表示することさえできませんでした: (どこが間違っているのでしょうか?)
[AllowAnonymous]
public ActionResult ResetPassword(string un, string rt)
{
UsersContext db = new UsersContext();
//Get userid of received username
var userid = (from i in db.UserProfiles
where i.UserName == un
select i.UserId).FirstOrDefault();
var yrpassword = (from k in db.webpages_Memberships
where k.UserId == userid
select k.Password);
TempData["Message"] = "This is your user name" + un;
TempData["Message"] = "This is your user-id" + userid;
TempData["Message"] = "This is your user password" + yrpassword;
return View();
}
これは、パスワード コントローラーのリセット アクションの現在のビュー ページです。
@model MvcApplication1.Models.webpages_Membership
@{
ViewBag.Title = "Reset Password";
}
<hgroup class="title">
<h1>@ViewBag.Title.</h1>
</hgroup>
<section id="loginForm">
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<legend>Password Reset Form</legend>
<ol>
<li>
@Html.LabelFor(m => m.Password)
@Html.TextBoxFor(m => m.Password)
@Html.ValidationMessageFor(m => m.Password)
</li>
</ol>
<input type="submit" value="Save" />
</fieldset>
<ol>
<li>
@Html.ActionLink("Login", "Login") You can now login to your account.
</li>
</ol>
}
</section>
更新クエリが必要であることはわかっていますが、どういうわけか正しく取得できません。