python可以做复杂网站,15年做啥网站致富,好的网站优化公司,简单项目计划书背景ASP.NET Core Identity 是一个完整的全功能身份验证提供程序#xff0c;用于创建和维护登录名。 但是#xff0c; cookie 不能使用基于的身份验证提供程序 ASP.NET Core Identity 。配置在 Startup.ConfigureServices 方法中#xff0c;创建具有 AddAuthentication 和 A… 背景ASP.NET Core Identity 是一个完整的全功能身份验证提供程序用于创建和维护登录名。 但是 cookie 不能使用基于的身份验证提供程序 ASP.NET Core Identity 。配置在 Startup.ConfigureServices 方法中创建具有 AddAuthentication 和 AddCookie 方法的身份验证中间件服务 services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme).AddCookie(); app.UseAuthentication();
AuthenticationScheme 传递到 AddAuthentication 设置应用程序的默认身份验证方案。如果有多个 cookie 身份验证实例并且你想要使用特定方案进行授权AuthenticationScheme 会很有用。将 AuthenticationScheme 设置为CookieAuthenticationDefaults。AuthenticationScheme为方案提供值 cookie。可以提供任何用于区分方案的字符串值。应用的身份验证方案不同于应用的 cookie 身份验证方案。如果未向 AddCookie提供 cookie 身份验证方案则使用 CookieAuthenticationDefaults.AuthenticationScheme Cookie。默认情况下身份验证 cookie 的 IsEssential 属性设置为 true。当站点访问者未同意数据收集时允许使用身份验证 cookie。 登录若要创建保存用户信息的 cookie请构造一个 ClaimsPrincipal。将对用户信息进行序列化并将其存储在 cookie 中。使用任何所需的 Claim创建 ClaimsIdentity并调用 SignInAsync 以登录用户 /// summary////// /summary/// param namemodel/param/// param namereturnUrl/param/// returns/returns[HttpPost][AllowAttribute][ValidateAntiForgeryToken]public async TaskIActionResult Login(LoginModel model, string returnUrl null){if (!ModelState.IsValid){return Json(new { state error, message 数据验证失败 });}string ip GetRemoteIpAddress();var r await UserApp.SaasLoginAsync(model.Account, model.Password, ip);if (!string.IsNullOrEmpty(r.Error)){return Json(new { state error, message r.Error });}var claims new ListClaim{new Claim(ClaimTypes.UserData, getCurrentUser(r.User, ip).ToString()),};var claimsIdentity new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);var authProperties new AuthenticationProperties{ExpiresUtc DateTimeOffset.Now.AddMinutes(120)};await HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme,new ClaimsPrincipal(claimsIdentity),authProperties);return Json(new { state success, message 登录成功。, returnUrl RedirectToLocal(returnUrl) });}SignInAsync 创建加密的 cookie并将其添加到当前响应中。如果未指定 AuthenticationScheme则使用默认方案。ASP.NET Core 的数据保护系统用于加密。对于托管在多台计算机上的应用程序、跨应用程序或使用 web 场进行负载平衡请将数据保护配置为使用相同的密钥环和应用程序标识符。注销 若要注销当前用户并删除其 cookie请调用 SignOutAsync /// summary////// /summary/// returns/returns[HttpPost][ValidateAntiForgeryToken]public async TaskIActionResult LogOff(){if (bool.Parse(Configuration.GetSection(IsIdentity).Value)){return SignOut(Cookies, oidc);}else{if (User.Identity.IsAuthenticated){string userdata User.Claims.FirstOrDefault(o o.Type ClaimTypes.UserData)?.Value;await UserApp.LogOffAsync(CurrentUser.FromJson(userdata));}await HttpContext.SignOutAsync(CookieAuthenticationDefaults.AuthenticationScheme);return RedirectToAction(actionName: nameof(Login), controllerName: Account);}}
参考资料https://docs.microsoft.com/zh-cn/aspnet/core/security/authentication/?viewaspnetcore-5.0