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

时间:2023-03-09 01:28:57
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);
}