在asp.net中实现自定义的application_end方法

时间:2011-04-16 09:37:42

标签: asp.net application-end

我希望有一个方法在会话到期或用户注销或用户关闭Web应用程序时执行。我怎样才能在asp.net中捕获这些事件并执行一个方法? 我在vs 2008 / asp.net / c#。

中构建了一个Web应用程序

请帮帮我。

感谢您的期待

2 个答案:

答案 0 :(得分:2)

use Global.asax file 

请参阅链接以使用Global.asax文件http://www.dotnetcurry.com/ShowArticle.aspx?ID=126

答案 1 :(得分:1)

右键单击解决方案,然后在解决方案中添加新项目Add Global.asax 其中有以下事件

 <script runat="server">



        void Application_Start(object sender, EventArgs e)
        {
            // Code that runs on application startup
            //Utils.LoadExtensions();

        }

        void Application_End(object sender, EventArgs e)
        {
            ClsCollege ObjClsColledge = new ClsCollege();
            ObjClsColledge.TruncateAllUserDetails(Session["UserSessionId"].ToString());
            ObjClsColledge.TruncateAllUserDetailsPrefrance(Session["UserSessionId"].ToString());

        }

        void Application_Error(object sender, EventArgs e)
        {

            HttpContext context = ((HttpApplication)sender).Context;
            Exception ex = context.Server.GetLastError();
            if (ex == null || !(ex is HttpException) || (ex as HttpException).GetHttpCode() == 404)
            {
                return;
            }
            StringBuilder sb = new StringBuilder();

            try
            {
                sb.AppendLine("Url : " + context.Request.Url);
                sb.AppendLine("Raw Url : " + context.Request.RawUrl);

               while (ex != null)
                {
                    sb.AppendLine("Message : " + ex.Message);
                   sb.AppendLine("Source : " + ex.Source);
                   sb.AppendLine("StackTrace : " + ex.StackTrace);
                   sb.AppendLine("TargetSite : " + ex.TargetSite);
                   ex = ex.InnerException;
                }
            }
            catch (Exception ex2)
            {
                sb.AppendLine("Error logging error : " + ex2.Message);
            }

            if (BlogSettings.Instance.EnableErrorLogging)
            {
               Utils.Log(sb.ToString());
           }
            context.Items["LastErrorDetails"] = sb.ToString();
            context.Response.StatusCode = 500;

            //// Custom errors section defined in the Web.config, will rewrite (not redirect)
            //// this 500 error request to error.aspx.


        }

        void Session_Start(object sender, EventArgs e)
        {




         }

        void Session_End(object sender, EventArgs e)
        {
            ClsCollege ObjClsColledge = new ClsCollege();
            ObjClsColledge.TruncateAllUserDetails(Session["UserSessionId"].ToString());
            ObjClsColledge.TruncateAllUserDetailsPrefrance(Session["UserSessionId"].ToString());
        }






</script>

事件Session_start(),Session_End()和Application_End()您将能够跟踪 事件