我正在尝试将 HttpContext.Session 保存到数据库而不是内存服务器中
问题是什么都没有保存在表中, session 总是为空。
这是我的启动代码:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
services.AddDistributedSqlServerCache(options =>
{
options.ConnectionString = @"Data Source=localhost;Initial Catalog=mydb;Integrated Security=True;";
options.SchemaName = "dbo";
options.TableName = "SQLSessions";
});
services.AddSession(options => {
options.CookieName = "Test.Session";
options.IdleTimeout = TimeSpan.FromMinutes(60);
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory, IDistributedCache cache)
{
loggerFactory.AddConsole(Configuration.GetSection("Logging"));
loggerFactory.AddDebug();
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
app.UseDatabaseErrorPage();
app.UseBrowserLink();
}
else
{
app.UseExceptionHandler("/Home/Error");
}
app.UseStaticFiles();
app.UseSession();
app.UseForwardedHeaders(new ForwardedHeadersOptions
{
ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto
});
app.UseHttpMethodOverride();
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}"
);
routes.MapRoute(
name: "AdvertisementImages",
template: "{controller=Home}/{action=Images}/{type}/{name}", // URL with parameters
defaults: new {type = 0, name = ""} // Parameter defaults
);
});
}
和我用于保存 session 的 Controller 代码:
HttpContext.Session.SetObjectAsJson("TryToLogin", newLogin);
和我的 session 扩展:
public static class SessionExtensions
{
public static void SetObjectAsJson(this ISession session, string key, object value)
{
session.SetString(key, JsonConvert.SerializeObject(value));
}
public static T GetObjectFromJson<T>(this ISession session, string key)
{
var value = session.GetString(key);
return value == null ? default(T) : JsonConvert.DeserializeObject<T>(value);
}
}
这是我的 session 表架构:
最佳答案
我建议您阅读以下教程:
- Microsoft document about distributed cache
- Configuring SQL Server For Session State In ASP.NET Core 1.0 MVC
我希望这对您有所帮助;)
关于session - AddDistributedSqlServerCache 没有将 session 保存到数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43198332/