zoukankan      html  css  js  c++  java
  • .net中Global.asax

    Global.asax全局应用程序文件,继承自HttpApplication类,维护HttpApplication对象池。包含以下事件
    Application_Init 和Application_Start 事件在应用程序第一次启动时被触发一次
    Application_Disposed 和 Application_End 事件在应用程序终止时被触发一次
    以下事件被触发的顺序:
    Application_BeginRequest 
    接收到应用程序请求时候触发,他是第一个被触发的事件,请求时用户输入的页面的URL。
    Application_AuthenticateRequest 
    在安全模块建立起当前用户的有效的身份时,该事件被触发。在这个时候,用户的凭据将会被验证。
    Application_AuthorizeRequest
    当安全模块确认一个用户可以访问资源之后,该事件被触发。
    Application_ResolveRequestCatche
    在 ASP.NET 页面框架完成一个授权请求时,该事件被触发。它允许缓存模块从缓存中为请求提供服务,从而绕过事件处理程序的执行。
    Application_AcquireRequestState
    在 ASP.NET 页面框架得到与当前请求相关的当前状态(Session 状态)时,该事件被触发。
    Application_PerRequestHandlerExecute
    在 ASP.NET 页面框架开始执行诸如页面或 Web 服务之类的事件处理程序之前,该事件被触发。
    Application_PerSendRequestHeaders
    在 ASP.NET 页面框架发送 HTTP 头给请求客户(浏览器)时,该事件被触发。
    Application_PerSendRequestContent
    在 ASP.NET 页面框架发送内容给请求客户(浏览器)时,该事件被触发。
    <页面代码>
    Application_PostRequestHandlerExecute
    在 ASP.NET 页面框架结束执行一个事件处理程序时,该事件被触发。
    Application_ReleaseRequestState
    在 ASP.NET 页面框架执行完所有的事件处理程序时,该事件被触发。这将导致所有的状态模块保存它们当前的状态数据。
    Application_UpdateRequestCatche
    在 ASP.NET 页面框架完成事件处理程序的执行时,该事件被触发,从而使缓存模块存储响应数据,以供响应后续的请求时使用。
    Application_EndRequest
    针对应用程序请求的最后一个事件。

    Session_Start:在一个新用户访问应用程序 Web 站点时,该事件被触发。
    Session_End:在一个用户的会话超时、结束或他们离开应用程序 Web 站点时,该事件被触发。

    .net在Global.asax里面实现站点访问统计


    具体的原理是:
    在application开始的时候从一个文件里读取数字放进一个Application里,
    这样主要是防止在站点重启的时候清零了
    然后就是Session_Start,变量+1,
    在Application_End时候再更新数据一次,
    代码如下:

    <%@ Application Language="C#" %>
    <%@ Import  Namespace = "System.Data.SqlClient" %>

    <script runat="server">

        void Application_Start(object sender, EventArgs e)
        {
            // 在应用程序启动时运行的代码
            SqlConnection con = new SqlConnection();
            con.ConnectionString = ConfigurationManager.ConnectionStrings["TongJiConnectionString"].ConnectionString;
            con.Open();
            SqlCommand cmd = new SqlCommand("select * from liulantongji", con);
            int count = Convert.ToInt32(cmd.ExecuteScalar());
            con.Close();
            Application["total"] = count;
            
        }
        
        void Application_End(object sender, EventArgs e)
        {
            //  在应用程序关闭时运行的代码
            SqlConnection con = new SqlConnection();
            con.ConnectionString = ConfigurationManager.ConnectionStrings["TongJiConnectionString"].ConnectionString;
            con.Open();
            SqlCommand cmd = new SqlCommand("update liulantongji set totalnum =" + Application["total"].ToString(), con);
            cmd.ExecuteNonQuery();
            con.Close();
          
        }
            
        void Application_Error(object sender, EventArgs e)
        {
            // 在出现未处理的错误时运行的代码

        }

        void Session_Start(object sender, EventArgs e)
        {
            Session["admin"] = null;
            Session["admintype"] = null;  
            // 在新会话启动时运行的代码
            Application.Lock();
            Application["total"] =Convert.ToInt32(Application["total"] )+ 1;      
            Application.UnLock();

        }

        void Session_End(object sender, EventArgs e)
        {
            // 在会话结束时运行的代码。
            // 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
            // InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer
            // 或 SQLServer,则不会引发该事件。
            
          

        }
          
    </script>

  • 相关阅读:
    [转载]java日志框架log4j详细配置及与slf4j联合使用教程
    log4j的正确使用姿势
    eclipse 安装properties编辑器,显示中文
    tips:解决bootstrap-switch 在jqgrid中动态加载不显示的问题
    jqgrid 设置为每行单选
    MySQL 批量修改某一列的值为另外一个字段的值
    MySQL 使用左连接替换not in
    分析一个react项目
    React不同版本之间需要注意的地方
    一个出色的表格(React实现__ES5语法)
  • 原文地址:https://www.cnblogs.com/pipizhu/p/1591917.html
Copyright © 2011-2022 走看看