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);
                }
posted @ 2014-09-03 23:20  倚舟笑沧海  阅读(1836)  评论(0编辑  收藏  举报