私は1つのメソッドでセッション変数を設定し、コントローラーの別のメソッドからセッション変数値を取得しようとしていますが、常にnullを取得しています:
ここに私のコード:
public class HomeController : Controller
{
public IActionResult Index()
{
HttpContext.Session.SetString("Test", "Hello!");
var message = HttpContext.Session.GetString("Test");// Here value is getting correctly
return View();
}
public IActionResult About()
{
var message = HttpContext.Session.GetString("Test"); // This value is always getting null here
return View();
}
}
ここにStartup
クラスのセッション構成があります
ConfigureServices()
メソッドの場合:
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.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
services.AddDistributedMemoryCache();
services.AddMvc().AddSessionStateTempDataProvider();
services.AddSession(options =>
{
options.Cookie.Name = "TanvirArjel.Session";
options.IdleTimeout = TimeSpan.FromDays(1);
});
Configure()
メソッドの場合:
app.UseSession();
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
非常に奇妙で奇妙な問題です!どんな助けでも大歓迎です!
StartupクラスのConfigureServices
メソッドで、options.CheckConsentNeeded = context => false;
を次のように設定します。
services.Configure<CookiePolicyOptions>(options =>
{
// This lambda determines whether user consent for non-essential cookies is needed for a given request.
options.CheckConsentNeeded = context => false;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
問題が解決しました!
ここで説明するようにCookie.IsEssential = true
を設定することもできます。 https://andrewlock.net/session-state-gdpr-and-non-essential-cookies/
services.AddSession()
のオーバーロードがあり、SessionOptions
ファイルでStartup
を構成できます。セッションタイムアウトなどのさまざまな設定を変更できます。また、セッションCookieをカスタマイズすることもできます。 Cookieを必須としてマークするには、IsEssential
をtrueに設定します。
public void ConfigureServices(IServiceCollection services)
{
services.Configure<CookiePolicyOptions>(options =>
{
options.CheckConsentNeeded = context => true; // consent required
options.MinimumSameSitePolicy = SameSiteMode.None;
});
services.AddSession(opts =>
{
opts.Cookie.IsEssential = true; // make the session cookie Essential
});
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
}