首页 > Web开发 > 详细

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

时间:2014-09-04 00:03:17      阅读:521      评论:0      收藏:0      [点我收藏+]

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

原文:http://www.cnblogs.com/bushuosx/p/3955011.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!