我正在使用 mvc4 应用程序内置帐户注册和登录 Controller (及其各自的模型)。我有自己的删除帐户的方法。因此,我想在标准登录 Controller 中进行检查,以便它检查我是否自己删除了帐户,然后将用户重定向到信息页面。
但是,当 Controller 被调用时,它只是传递我的代码行并仍然让用户登录。我已经检查了数据库。用户将其 IsActive(将帐户列为“事件”和“非事件”)值设置为 0,并且应该被重定向。但他只是登录就像我的代码行不存在一样...
这是 Controller 中的代码:
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult Login(LoginModel model, string returnUrl)
{
if (WorkerDAL.IsActive(model.UserName)) RedirectToAction("DisplayDeletedUserMessage", "Home"); //my redirect code
if (ModelState.IsValid && WebSecurity.Login(model.UserName, model.Password, persistCookie: model.RememberMe))
{
return RedirectToLocal(returnUrl);
}
// If we got this far, something failed, redisplay form
ModelState.AddModelError("", "The user name or password provided is incorrect.");
return View(model);
}
我的 DAL 类的代码:
public static bool IsActive(string _username)
{ TimeTrackerEntities db = new TimeTrackerEntities();
foreach (Worker worker in db.Workers)
{
if (worker.UserName == _username)
{
if (worker.IsActive == 1) return true;
if (worker.IsActive == 0) return false;
}
}
return true;
}
我是否对用户使用了错误的重定向操作?或者类似这样明显的事情?我基本上迷路了...
编辑 - 感谢 Eric J. 和 Jonathon Page,代码现在可以工作了。谢谢你们俩! 我怎样才能将他们的评论记为正确答案?
最佳答案
我假设这一行:
if (WorkerDAL.IsActive(model.UserName)) RedirectToAction("DisplayDeletedUserMessage", "Home");
应该阅读
if (!WorkerDAL.IsActive(model.UserName)) RedirectToAction("DisplayDeletedUserMessage", "Home");
如果用户处于事件状态,您当前正在重定向以显示已删除的用户消息。
关于c# - 无法修改 MVC 4 内置登录 Controller ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14917418/