我已经设置了一个ASP。SQL数据库上的NET会话状态服务器:
<sessionState timeout="60" allowCustomSqlDatabase="true" mode="SQLServer" sqlConnectionString="..." />
我有一个默认的错误重定向:
<customErrors mode="On" defaultRedirect="~/Error.aspx" />
Global.asax.cs:
private void Application_Error( object sender, EventArgs e )
{
SomeSessionObj sessionObj = new SomeSessionObj();
sessionObj.SomeProperty1 = true;
sessionObj.SomeProperty2 = new Blabla();
HttpContext.Current.Session["FooBar"] = sessionObj;
}
错误.aspx。cs:
protected void Page_Load( object sender, EventArgs e )
{
SomeSessionObj sessionObj = HttpContext.Current.Session["FooBar"] as SomeSessionObj;
// sessionObj is NOT NULL
// sessionObj.SomeProperty1 is false
// sessionObj.SomeProperty2 is NULL
}
SomeSessionObj和SomeProperty类都标记为Serializable。
如果没有State Server(inProc),它将按预期工作。
提前谢谢。
好的,开始工作了。
使用会话状态服务器时,必须调用服务器。Application_Error中的ClearError(),否则请求将被终止,会话状态将不会被写入。
void Application_Error(object sender, EventArgs e)
{
Exception ex = Server.GetLastError();
HttpContext.Current.Session["Error"] = ex.Message;
Response.Redirect("error.aspx",false);
Server.ClearError();
}