在 ASP.NET Core 6 的应用程序中,有时会出现将 Cookie 返回给浏览器,但 Cookie 在浏览器中未被保存的问题。这可能是由于使用响应方式不正确或浏览器不支持 Cookie 导致的。
解决此问题的方法是使用 ASP.NET Core 提供的 CookieAuthentication 手动配置选项。可以通过在 Startup.cs 中的 ConfigureServices 方法中进行配置来解决此问题。
具体来说,您可以使用以下代码示例来解决此问题:
services.Configure(options =>
{
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme)
.AddCookie(options =>
{
options.Cookie.Name = "YourCookieName";
options.Cookie.SameSite = SameSiteMode.None;
options.Cookie.SecurePolicy = CookieSecurePolicy.SameAsRequest;
options.Cookie.HttpOnly = true;
options.Cookie.IsEssential = true;
options.LoginPath = "/Account/Login";
options.LogoutPath = "/Account/Logout";
options.AccessDeniedPath = "/Account/AccessDenied";
options.ExpireTimeSpan = TimeSpan.FromMinutes(60);
});
在这个示例中,我们手动配置了 CookieAuthentication。请注意,我们使用了 SomeSiteMode.None 和 CookieSecurePolicy.SameAsRequest,这意味着 Cookie 可以与一些较旧的浏览器兼容,并在不同的 URL 上使用相同的 Cookie。
此外,我们还设置了 CookieAuthenticationDefaults.AuthenticationScheme,这个值是选项中的默认身份验证方案。
最后,ResumeSignInAsync 方法应该使用 SignInAsync 方法签名。```