尝试在 MVC 中扩展 UserPrincipal 不起作用
Attempt to extend UserPrincipal in MVC not working
我尝试在 MVC 中扩展 UserPrincipal 方法,但我无法弄清楚为什么它不起作用。
我的代码:
interface ICustomPrincipal : IPrincipal
{
Guid AuthId { get; set; }
Role UserRole { get; set; }
}
public class CustomPrincipal : ICustomPrincipal
{
public IIdentity Identity { get; private set; }
public bool IsInRole(string role) { return false; }
public CustomPrincipal(string email)
{
this.Identity = new GenericIdentity(email);
}
public Guid AuthId { get; set; }
public Role UserRole { get; set; }
}
public class CustomPrincipalSerializeModel
{
public Guid AuthId { get; set; }
public Role UserRole { get; set; }
}
我的身份用户:
public class ApplicationUser : IdentityUser
{
public async Task<ClaimsIdentity> GenerateUserIdentityAsync(UserManager<ApplicationUser> manager)
{
// Note the authenticationType must match the one defined in CookieAuthenticationOptions.AuthenticationType
var userIdentity = await manager.CreateIdentityAsync(this, DefaultAuthenticationTypes.ApplicationCookie);
// Add custom user claims here
return userIdentity;
}
public Guid UserIdMatch { get; set; }
public Role Role { get; set; }
}
因此,当创建用户时,他们会获得 authId 和角色。
当用户登录/注册时:
var user = db.Users.Include(i => i.Role).FirstOrDefault(i => i.UserName == model.Username);
CustomPrincipalSerializeModel serializeModel = new CustomPrincipalSerializeModel();
serializeModel.AuthId = user.UserIdMatch;
serializeModel.UserRole = user.Role;
JavaScriptSerializer serializer = new JavaScriptSerializer();
string userData = serializer.Serialize(serializeModel);
FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(
1,
user.UserName,
DateTime.Now,
DateTime.Now.AddDays(1),
false,
userData
);
string encTicket = FormsAuthentication.Encrypt(authTicket);
HttpCookie faCookie = new HttpCookie(FormsAuthentication.FormsCookieName, encTicket);
Response.Cookies.Add(faCookie);
最后在我的 Global.asax
我有以下代码:
protected void Application_PostAuthenticateRequest(Object sender, EventArgs e)
{
HttpCookie authCookie = Request.Cookies[FormsAuthentication.FormsCookieName];
if (authCookie != null)
{
FormsAuthenticationTicket authTicket = FormsAuthentication.Decrypt(authCookie.Value);
JavaScriptSerializer serializer = new JavaScriptSerializer();
CustomPrincipalSerializeModel serializeModel = serializer.Deserialize<CustomPrincipalSerializeModel>(authTicket.UserData);
CustomPrincipal newUser = new CustomPrincipal(authTicket.Name);
newUser.AuthId = serializeModel.AuthId;
HttpContext.Current.User = newUser;
}
}
在我看来应该没问题,但是当我在任何页面上调用@((User as CustomPrincipalSerializeModel).AuthId)
时,它会抛出以下错误:
Object reference not set to an instance of an object.
注意:假设我调试登录时。我没有收到任何错误,我可以看到 cookie 有正确的数据。
谁能指出问题所在?
您将用户设置为 CustomPrincipal
,但您希望它是 CustomPrincipalSerializeModel
。由于两者无关,所以这肯定行不通。
我敢打赌你的意思是
@((User as CustomPrincipal).AuthId
因为 AuthId
属性 似乎同时出现在 类.
中
我尝试在 MVC 中扩展 UserPrincipal 方法,但我无法弄清楚为什么它不起作用。
我的代码:
interface ICustomPrincipal : IPrincipal
{
Guid AuthId { get; set; }
Role UserRole { get; set; }
}
public class CustomPrincipal : ICustomPrincipal
{
public IIdentity Identity { get; private set; }
public bool IsInRole(string role) { return false; }
public CustomPrincipal(string email)
{
this.Identity = new GenericIdentity(email);
}
public Guid AuthId { get; set; }
public Role UserRole { get; set; }
}
public class CustomPrincipalSerializeModel
{
public Guid AuthId { get; set; }
public Role UserRole { get; set; }
}
我的身份用户:
public class ApplicationUser : IdentityUser
{
public async Task<ClaimsIdentity> GenerateUserIdentityAsync(UserManager<ApplicationUser> manager)
{
// Note the authenticationType must match the one defined in CookieAuthenticationOptions.AuthenticationType
var userIdentity = await manager.CreateIdentityAsync(this, DefaultAuthenticationTypes.ApplicationCookie);
// Add custom user claims here
return userIdentity;
}
public Guid UserIdMatch { get; set; }
public Role Role { get; set; }
}
因此,当创建用户时,他们会获得 authId 和角色。
当用户登录/注册时:
var user = db.Users.Include(i => i.Role).FirstOrDefault(i => i.UserName == model.Username);
CustomPrincipalSerializeModel serializeModel = new CustomPrincipalSerializeModel();
serializeModel.AuthId = user.UserIdMatch;
serializeModel.UserRole = user.Role;
JavaScriptSerializer serializer = new JavaScriptSerializer();
string userData = serializer.Serialize(serializeModel);
FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(
1,
user.UserName,
DateTime.Now,
DateTime.Now.AddDays(1),
false,
userData
);
string encTicket = FormsAuthentication.Encrypt(authTicket);
HttpCookie faCookie = new HttpCookie(FormsAuthentication.FormsCookieName, encTicket);
Response.Cookies.Add(faCookie);
最后在我的 Global.asax
我有以下代码:
protected void Application_PostAuthenticateRequest(Object sender, EventArgs e)
{
HttpCookie authCookie = Request.Cookies[FormsAuthentication.FormsCookieName];
if (authCookie != null)
{
FormsAuthenticationTicket authTicket = FormsAuthentication.Decrypt(authCookie.Value);
JavaScriptSerializer serializer = new JavaScriptSerializer();
CustomPrincipalSerializeModel serializeModel = serializer.Deserialize<CustomPrincipalSerializeModel>(authTicket.UserData);
CustomPrincipal newUser = new CustomPrincipal(authTicket.Name);
newUser.AuthId = serializeModel.AuthId;
HttpContext.Current.User = newUser;
}
}
在我看来应该没问题,但是当我在任何页面上调用@((User as CustomPrincipalSerializeModel).AuthId)
时,它会抛出以下错误:
Object reference not set to an instance of an object.
注意:假设我调试登录时。我没有收到任何错误,我可以看到 cookie 有正确的数据。
谁能指出问题所在?
您将用户设置为 CustomPrincipal
,但您希望它是 CustomPrincipalSerializeModel
。由于两者无关,所以这肯定行不通。
我敢打赌你的意思是
@((User as CustomPrincipal).AuthId
因为 AuthId
属性 似乎同时出现在 类.