修改UserController中[HttpPost]方式的ChangePassword()以实现修改密码,修改完成的代码如下:
[HttpPost]
[UserAuthorize]
public ActionResult ChangePassword(UserChangePassword userChangePassword)
{
userRsy = new UserRepository();
if (userRsy.Authentication(UserName, Common.Text.Sha256(userChangePassword.Password)) == 0)
{
var _user = userRsy.Find(UserName);
if (_user == null)
{
Error _e = new Error { Title = "修改密码失败", Details = "修改密码时,系统查询不到用户信息", Cause = Server.UrlEncode("<li>用户在修改密码界面停留的时间过长,登录信息已失效。</li><li>系统错误。</li>"), Solution = Server.UrlEncode("<li>返回<a href='" + Url.Action("ChangePassword", "User") + "'>修改密码</a>页面,输入正确的信息后重新注册</li><li>联系网站管理员</li>") };
return RedirectToAction("Error", "Prompt", _e);
}
_user.Password = Common.Text.Sha256(userChangePassword.NewPassword);
if (userRsy.Update(_user))
{
Notice _n = new Notice { Title = "成功修改密码", Details = "您已经成功修改密码,请牢记您的新密码!", DwellTime = 5, NavigationName = "登陆页面", NavigationUrl = Url.Action("Login", "User") };
return RedirectToAction("Notice", "Prompt", _n);
}
else
{
Error _e = new Error { Title = "修改密码失败", Details = "修改密码时,更新数据库失败!", Cause = Server.UrlEncode("<li>系统错误。</li>"), Solution = Server.UrlEncode("<li>返回<a href='" + Url.Action("ChangePassword", "User") + "'>修改密码</a>页面,输入正确的信息后重新注册</li><li>联系网站管理员</li>") };
return RedirectToAction("Error", "Prompt", _e);
}
}
else
{
ModelState.AddModelError("Password", "原密码不正确,请重新输入");
return View();
}
}
在上面的代码中用到了一个UserName属性,这个是在UserController添加的属性用于返回Cookie中保存的用户名
/// <summary>
/// 获取用户名
/// </summary>
public string UserName {
get {
HttpCookie _cookie = Request.Cookies["User"];
if (_cookie == null) return "";
else return _cookie["UserName"];
}
}
好了,浏览器中预览一下
测试一下,OK,大功告成!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易采站长站。








