Asp.Net Identity自定义user类的运用,ClaimsIdentity
mvc5自动生成的用户验证是比较好用的,还可以扩展,可是要求code first,目前使用sqlite,支持entity framework,但不支持code first。
只有自已简单模仿一下了。经过实验,如下几条后,可以运行了。
webconfig
<appSettings> <add key="webpages:Version" value="3.0.0.0" /> <add key="webpages:Enabled" value="false" /> <add key="ClientValidationEnabled" value="true" /> <add key="UnobtrusiveJavaScriptEnabled" value="true" /> <add key="owin:AutomaticAppStartup" value="true" /> </appSettings>
Startup.Auth.cs
public partial class Startup { public void ConfigureAuth(IAppBuilder app) { app.UseCookieAuthentication(new CookieAuthenticationOptions { AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie, LoginPath = new PathString("/Account/Login"), });
} }
claim identity 相关接口,方法
public interface IUserIdentity { string Id { get; set; } string UserName { get; set; } } public static ClaimsIdentity CreateIdentity<TUserIdentity>(TUserIdentity user) where TUserIdentity : IUserIdentity { ClaimsIdentity identity = new ClaimsIdentity(DefaultAuthenticationTypes.ApplicationCookie); identity.AddClaim(new Claim("http://schemas.microsoft.com/accesscontrolservice/2010/07/claims/identityprovider", "ASP.NET Identity")); identity.AddClaim(new Claim(ClaimTypes.Name, user.UserName)); identity.AddClaim(new Claim(ClaimTypes.NameIdentifier, user.Id)); //identity.AddClaim(new Claim(ClaimTypes.PrimarySid, user.Id)); //identity.AddClaim(new Claim("DisplayName", user.UserName)); return identity; }
signinmanager
private IAuthenticationManager AuthenticationManager { get { return HttpContext.GetOwinContext().Authentication; } } var user = AppUserIdentityService.FindAsync(loginViewModel.UserName, loginViewModel.Password, db.MyUsers); if (user == null || user.Result == null) ModelState.AddModelError("", "用户名或密码不正确"); else { ClaimsIdentity identity = AppUserIdentityService.CreateIdentity(user.Result); AuthenticationManager.SignOut(DefaultAuthenticationTypes.ApplicationCookie); AuthenticationManager.SignIn(new AuthenticationProperties() { IsPersistent = loginViewModel.RememberMe }, identity); return RedirectToLocal(returnUrl); }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。