这个问题可能有很多重复项。但我忽略了 MVC 的默认成员身份,并使用我的自定义登录和 cookie。这就是为什么不能像示例中那样创建自定义授权属性。我有这样的用户模型:
public class MyUserModel
{
public string Id{ get; set; }
public string UserName { get; set; }
public string Password { get; set; }
public bool RememberMe { get; set; }
public bool RoleId { get; set; }
}
这是我的登录操作:
[HttpPost]
public ActionResult LogIn(MyUserModel model)
{
if ((Request.Browser.Cookies))
{
if ((Request.Cookies["UserInfo"] == null))
{
if (model.RememberMe)
{
Response.Cookies["UserInfo"].Expires = DateTime.Now.AddDays(30);
}
else
{
Response.Cookies["UserInfo"].Expires = DateTime.Now.AddMinutes(Session.Timeout);
}
Response.Cookies["UserInfo"]["UserName"] = model.UserName;
Response.Cookies["UserInfo"]["Password"] = model.Password;
Response.Cookies["UserInfo"]["Id"] = model.Id.ToString();
}
else
{
Response.Cookies["UserInfo"]["UserName"] = model.UserName;
Response.Cookies["UserInfo"]["Password"] = model.Password;
Response.Cookies["UserInfo"]["Id"] = model.Id.ToString();
}
}
return RedirectToAction("Index", "Home");
}
我需要通过RoleId创建自定义授权属性。顺便说一句,我已经
bool UserInRole(roleId), bool IsUserAuthenticated()
准备好了方法。
抱歉英语不好。