首先管理员应该可以随进重置所有用户的密码。所以我设置了一个重置功能。

一般在具有用户注册和登录的网站中,都会有重置密码的功能,该功能让用户在

忘记密码的情况下,重新再设置一个密码。

不过我现在不想学邮箱重置密码,我.仅想先用管理员进行秘码的重置。

 1. 编写 ResetPasswordViewModel
using System.ComponentModel.DataAnnotations;

namespace jsdhh2.ViewModels
{
	public class ResetPasswordViewModel
	{
		[Required]
		[EmailAddress]
		[Display(Name = "电子邮件")]
		public string Email { get; set; }

		[Required]
		[StringLength(100, ErrorMessage = "{0} 必须至少包含 {2} 个字符。", MinimumLength = 6)]
		[DataType(DataType.Password)]
		[Display(Name = "密码")]
		public string Password { get; set; }

		[DataType(DataType.Password)]
		[Display(Name = "确认密码")]
		[Compare("Password", ErrorMessage = "密码和确认密码不匹配。")]
		public string ConfirmPassword { get; set; }

		public string Code { get; set; }
	}
}

  

 

重置链接是从邮箱跳转过来的,并且链接上包含 userid
和 code,这是重置密码的条件。

.2. 编写 ResetPassword 方法

在“UserController”控制器中,编写两个 ResetPassword()方法,一个带有 HttpGet特性,一个带有 HttpPost 特性。代码如下:

/// <summary>
		/// 重置密码
		/// </summary>
		/// <param name="code"></param>
		/// <returns></returns>
		[HttpGet]
		[AllowAnonymous]
		public ActionResult ResetPassword(string code)
		{
			return code == null ? View("Error") : View();
		}

		/// <summary>
		/// 重置密码
		/// </summary>
		/// <param name="model"></param>
		/// <returns></returns>
		[HttpPost]
		[AllowAnonymous]
		[ValidateAntiForgeryToken]
		public async Task<ActionResult> ResetPassword(jsdhh2.ViewModels.ResetPasswordViewModel model)
		{
			if (!ModelState.IsValid)
			{
				return View(model);
			}
			var user = await UserManager.FindByNameAsync(model.Email);
			if (user == null)
			{
				return View("Error");
			}
			var result = await UserManager.ResetPasswordAsync(user.Id, model.Code, model.Password);
			if (result.Succeeded)
			{
				return RedirectToAction("ResetPasswordConfirmation", "User");
			}
			AddErrors(result);
			return View();
		}

  

使用 UserManager.ResetPasswordAsync()方法就可以重置密码,这是 ASP.NETIdentity 提供的 API,我们只需要传入相应的参数即可。另外,在该代码中,还提到了“ResetPasswordConfirmation”方法,用于确认重置密码。只是提示信息,没有逻辑代码。

3. 编写 ResetPasswordConfirmation 方法:在“UserController”控制器中编写 ResetPasswordConfirmation()方法,如下代码:

[AllowAnonymous]
		public ActionResult ResetPasswordConfirmation()
		{
			return View();
		}

  由于 ResetPasswordConfirmation()方法返回的是默认视图,所以还需要关联一个,视图。

.7.4. 编写 ResetPasswordConfirmation 视图。

在“Views”“User”文件夹中添加“ResetPasswordConfirmation.cshtml”视图,并编写如下代码

@{
	ViewBag.Title = "重置密码确认";
}
<hgroup class="title">
	<h1>@ViewBag.Title。</h1>
</hgroup>
<div>
	<p>
		你的密码已重置。请
		@Html.ActionLink("单击此处登录", "Login", "User", routeValues: null,
htmlAttributes: new { id = "loginLink" })
	</p>
</div>

  

5. 编写 ResetPassword 视图

在“Views”“User”文件夹中添加“ResetPassword.cshtml”视图,并编写如下代码:

@model jsdhh2.ViewModels.ResetPasswordViewModel
@{
	ViewBag.Title = "重置密码";
}

@using (Html.BeginForm("ResetPassword", "User", FormMethod.Post, new { @class = "form-horizontal", role = "form" }))
{
	@Html.AntiForgeryToken()
	<h4>重置你的密码。</h4>
	<hr />
	@Html.ValidationSummary("", new { @class = "text-danger" })
	@Html.HiddenFor(model => model.Code)
	<div class="form-group">
		@Html.LabelFor(m => m.Email, new { @class = "col-md-2 control-label" })
		<div class="col-md-10">
			@Html.TextBoxFor(m => m.Email, new { @class = "form-control" })
		</div>
	</div>
	<div class="form-group">
		@Html.LabelFor(m => m.Password, new { @class = "col-md-2 control-label" })
		<div class="col-md-10">
			@Html.PasswordFor(m => m.Password, new { @class = "form-control" })
		</div>
	</div>
	<div class="form-group">
		@Html.LabelFor(m => m.ConfirmPassword, new { @class = "col-md-2 control-label" })
		<div class="col-md-10">
			@Html.PasswordFor(m => m.ConfirmPassword, new { @class = "form-control" })
		</div>
	</div>
	<div class="form-group">
		<div class="col-md-offset-2 col-md-10">
			<input type="submit" class="btn btn-default" value="重置" />
		</div>
	</div>
}

  

重置密码时,需要提供电子邮件地址和新密码。并且重置密码的链接必须是从邮件中过来的。因为,在邮件中的链接中包含 userid 和 code 值。

上面的代码完成后,现在运行一下,刷新一下图 7-39 的页面。如图 7-40 所示:

修改NetBIOS 计算机名_修改NetBIOS 计算机名

输入的电子邮件必须之前在网站中注册过,否则不能重置密码。完成后点击“重置”按钮。如图 7-42 所示

修改NetBIOS 计算机名_User_02

 

在图 7-42 中提示密码已经重置成功,可以登录了,现在使用新密码登录一下并且登录成功了,说明我们的重置密码也成功