.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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值