Cookie 没有使用以下代码附加到页面,我尝试将 IsEssential 添加到选项中,但它不起作用。使用 Asp.Net Core 3.1 Razor 页面。这是我的大部分startup.cs 和附加的cookie 代码。
启动.cs
public void ConfigureServices(IServiceCollection services)
{
services.Configure<CookiePolicyOptions>(options =>
{
// This lambda determines whether user consent for non-essential cookies is needed for a given request.
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
services.AddRazorPages();
services.AddMvc(config =>
{
var policy = new AuthorizationPolicyBuilder()
.RequireAuthenticatedUser()
.Build();
config.Filters.Add(new AuthorizeFilter(policy));
});
services.AddHttpContextAccessor();
services.TryAddSingleton<IActionContextAccessor, ActionContextAccessor>();
services.AddSignalR();
services.AddControllers().AddNewtonsoftJson();
services.AddControllersWithViews().AddNewtonsoftJson();
services.AddRazorPages().AddNewtonsoftJson();
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
}
app.UseRequestLocalization();
app.UseStaticFiles();
app.UseCookiePolicy();
app.useAuthentication();
app.UseRouting();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
{
endpoints.MapRazorPages();
endpoints.MapControllers();
});
}
添加cookie
string key = "Cookie";
var cookieValue = Request.Cookies[key];
if(cookieValue == null)
{
string value = "true";
var cookieOptions = new CookieOptions()
{
Path = "/",
HttpOnly = false,
IsEssential = true,
Expires = DateTime.Now.AddDays(1),
};
HttpContext.Response.Cookies.Append(key, value, cookieOptions);
}
建议添加 IsEssential 来覆盖 CookiePolicy,但这并没有解决任何问题。
Devtools 应用程序仅显示 .AspNetCore.Identity.Application 和 .AspNetCore.Antiforgery cookie。
编辑:
通过改变解决了
services.Configure<CookiePolicyOptions>(options =>
{
// This lambda determines whether user consent for non-essential cookies is needed for a given request.
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
to
services.ConfigureApplicationCookie(options =>
{
// Cookie settings
options.Cookie.HttpOnly = true;
options.ExpireTimeSpan = TimeSpan.FromMinutes(5);
options.LoginPath = "/Identity/Account/Login";
options.AccessDeniedPath = "/Identity/Account/AccessDenied";
options.SlidingExpiration = true;
});