首页 > 解决方案 > ASP.NET MVC - 自定义身份验证不起作用

问题描述

我创建了一个简单的身份验证表单来使用FormsAuthentication.

这就是我使用它的方式

public ActionResult LoginUser(Login login)
        {
            //var encodedPassword = HashPassword.Decode(login.Password);
            var encodedPassword = login.Password;
            var loginData = context.Accounts.Where(p => p.Username == login.Username && p.Password == encodedPassword).SingleOrDefault();

            if (loginData != null)
            {
                FormsAuthentication.SetAuthCookie(login.Username, false);


                return RedirectToAction("Index", "Home");
            }
            else
            {
                TempData["errMess"] = "Invalid credential";
                return RedirectToAction("Login");
            }
        }

现在我有一个代码可以在 _layout.cshtml 中获取登录用户名

<div class="profile_info">
   <span>
      Welcome,
      @if (Request.IsAuthenticated)
      {
         @Html.Encode(User.Identity.Name)
      }else {
         <strong>Hello worlds</strong>
      }
    </span>
</div>

但这并不能解决我的问题我做错了什么或者我错过了什么请帮助我我是新手dot net 谢谢!

标签: asp.net-mvcauthenticationforms-authentication

解决方案


你加了吗

<authentication mode="Forms">
      <forms loginUrl="~/Account/Login" timeout="2880" />
    </authentication>

里面<system.web>的部分web.config


推荐阅读