首页 > 代码库 > Asp.Net Identity自定义user类的运用,ClaimsIdentity

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);                }

Asp.Net Identity自定义user类的运用,ClaimsIdentity