gpt4 book ai didi

异常后 ASP.NET session 状态丢失

转载 作者:行者123 更新时间:2023-12-03 18:06:39 25 4
gpt4 key购买 nike

在最近的这个项目之前,我通常避免使用进程内 session 状态。我想我有一个问题,在发生未处理的异常后状态丢失。

这本身就很奇怪,因为请求上下文中的异常不会影响工作进程。它可能是后台线程或回调或其他方面的异常,但是,这是一个简单的站点,没有什么花哨的事情发生。

session ID 保持不变,并且不会在后续请求中调用 Session_Start(因此 WP 尚未回收)。

我启用了很多日志记录,很明显我从数据层收到一个异常,它是一个 HttpUnhandleException 内的 HttpException,然后当我立即浏览到主页时,请求会记录一个关于丢失的警告状态。

更差。这不会发生在我的开发箱(IIS Express)上,只发生在 QA 中。

编辑:

这是一大块日志:

2013-06-12 13:44:29,975 [23] FATAL MvcApplication 100.100.100.100 pxtgn GET An unhandled exception occurred in the web application. The full exception will be unrolled below.
2013-06-12 13:44:30,897 [23] FATAL MvcApplication 100.100.100.100 pxtgn GET Exception.Type: HttpUnhandledException
Exception.Source: System.Web
Exception.Message: Exception of type 'System.Web.HttpUnhandledException' was thrown.
Exception.StackTrace: at System.Web.UI.Page.HandleError(Exception e)
at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
at System.Web.UI.Page.ProcessRequest(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
at System.Web.HttpContext.InvokeCancellableCallback(WaitCallback callback, Object state)
at System.Web.UI.Page.LegacyAsyncPageBeginProcessRequest(HttpContext context, AsyncCallback callback, Object extraData)
at System.Web.HttpApplication.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute()
at System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously)

Exception.Type: HttpException
Exception.Source: CompanyNameProductName.MvcCoreApp
Exception.Message: An error was reported by the data layer: 0Image not found1-10.1007_978-1-4471-4294-2_21-16
Exception.StackTrace: at CompanyName.CompanyNameProductName.imagedetail.Page_Load(Object sender, EventArgs e) in c:\DATA\Git\ProductName\CompanyNameProductNameMvc\imagedetail.aspx.cs:line 55
at System.Web.UI.Control.LoadRecursive()
at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)


2013-06-12 13:45:07,913 [25] DEBUG StandardPage 100.100.100.100 pxtgn GET Initializing page 'default_aspx' for GET with query string:
2013-06-12 13:45:07,913 [25] ERROR StandardPage 100.100.100.100 pxtgn GET No User instance in session state. Check the log for signs that the session was started properly since a User object should aways exist in session state, setup via session start events in ASP.NET.

最后一行显示了缺失状态条件。 pxtgn 是 session ID 的前 5 个字符。我点击了一个页面,我知道数据层会因为不存在的图像 ID 而吐槽。然后我接下来点击的任何页面都会导致我的检查记录丢失状态的问题。检查和状态引用在母版页的代码中,所以我可以点击任何页面来查看问题。这也意味着自定义错误页面不起作用 - 这就是我找到错误的方式。

我现在添加了一个 Session.Abandon()在检查并回复 500 后让我出狱,但这是一个很奇怪的问题。我是代码库的新手,我想我已经到处检查 session 是否被清除或状态被覆盖。

最佳答案

1 线程被销毁
2 异步环境

使用 httpcontext 作为参数
不是 system.web.**.httpcontext

关于异常后 ASP.NET session 状态丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17069271/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com