zoukankan      html  css  js  c++  java
  • .Net如何统计在线人数

    统计在线用户的作用不言而喻,就是为了网站管理者可以知道当前用户的多少,然后根据用户数量来观察服务器或者程序的性能,从而可以直观的了解到网站的吸引力或者网站程序的效率现在,我们就介绍一个简单明了的方法来统计在线用户的多少,该方法的特点就是充分的利用了ASP.NET的特点,结合global.asax文件,用Application和Session巧妙的实现在线用户的统计,由于程序中只用到一个Application,所以,程序占用系统资源几乎可以忽略不及,当然,这也是网站管理者最关心的问题之一

    一用户显示页面的使用

    首先,我们来看看怎样现实当前网站的访问用户数量,程序代码如下:


    <%@ Page Language= "c# " debug= "true " %>
    <html>
    <head>
    <SCRIPT LANGUAGE= "c# " RUNAT= "server ">
    private void Page_Load(object sender, System.EventArgs e)
    {
    Visitors.Text = "本站当前有: <b> " + Application[ "user_sessions "].ToString() + " " + "</b> 位访问者 ! ";
    }
    <title>在线用户</title>
    </head>
    <body>
    <asp:label " runat= "server " /><br>
    </body>
    </html>

    可以看出,以上的程序特别简单,就是调用Application当然,我们不必要专门设计一个页面来显示在线用户数量,在网站的任何页面,我们都可以直接调用Application( "user_sessions ").ToString()来显示当前用户数量

    二global.asax文件实现

    global.asax文件的作用我们自不必说,现在,我们直接来看统计当前在线用户数量如何实现:


    <script language= "c# " runat= "Server ">
    protected void Application_Start(Object sender, EventArgs e)
    {
    Application[ "user_sessions "] = 0;
    }
    protected void Session_Start(Object sender, EventArgs e)
    {
    Application.Lock();
    Application[ "user_sessions "] = (int)Application[ "user_sessions "] + 1;
    Application.Unlock();
    }
    protected void Session_End(Object sender, EventArgs e)
    {
    Application.Lock();
    Application[ "user_sessions "] = (int)Application[ "user_sessions "] - 1;
    Application.Unlock();
    }
    </script>

    以上代码很容易理解,当网站开始服务的时候(Application开始的时候),程序设置Application[ "user_sessions "]为零,然后,当用户进入网站(Session开始的时候)的时候,锁定Application,然后,将application( "user_sessions ")加一,用户退出网站的时候,application( "user_sessions ")减一这样,就很巧妙的实现了在线用户的统计

    三一点讨论

    以上的统计,简明扼要,程序很容易实现但是,如果我们仔细考虑,发现该方法有一定的局限,统计出来的在线用户数量可能稍微有点误差因为我们在以上程序中,是根据用户建立和退出会话(Session)来实现在线人数的加减的,而我们知道,如果用户没有关闭浏览器,而进入另外一个网站,那么,这个会话在一定的时间内是不会结束的,这个时间我们可以通过TimeOut来设置,一般的,我们设置为20分钟所以,在用户数量统计上面,还是存在一点误差的

    另外,我们知道,在ASP中,如果用户将浏览器上面的Cookies设置为禁用,那么,Session就不能再被传递,显然,这样设置让以上的统计程序无能为力不过,在ASP.NET中我们有解决方法,在config.web文件中,我们将<sessionstate cookieless= "false " />设置为true就可以了,也就说,不使用Cookies也可以传递Session这样,我们的程序就可以在不同的访问者环境中顺利运行

    准备工作
    1、新建一个TongJi 的数据库,添加一个 tongji 的表,在表中有一个 Number 的字段,为 int 类型,Numger初值为1000;
    2、新建一个网站;
    3、新建数据库连接字符串(具体方法)并将其保存到Web.config 文件中, <connectionString>节的代码如下:

    <connectionStrings>
                <add name="TongJiConnectionString" connectionString="Data Source=.;Initial Catalog=TongJi;Integrated Security=True" providerName="System.Data.SqlClient"/>
            </connectionStrings>

    关键代码
    4、添加新项/全局应用程序类:Global.asax ,其文件的全部代码如下:




    <%@ 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 tongji", con);
                int count = Convert.ToInt32(cmd.ExecuteScalar());
                con.Close();
                Application["total"] = count;
                Application["online"] = 0;
            }
        
            void Application_End(object sender, EventArgs e)
            {
                //      在应用程序关闭时运行的代码
                SqlConnection con = new SqlConnection();
                con.ConnectionString=ConfigurationManager.ConnectionStrings["TongJiConnectionString"].ConnectionString;
                con.Open();
                SqlCommand cmd = new SqlCommand("update tongji set Number=" + Application["total"].ToString(), con);
                cmd.ExecuteNonQuery();
                con.Close();
            }
            
            void Application_Error(object sender, EventArgs e)
            {
                // 在出现未处理的错误时运行的代码
            }

            void Session_Start(object sender, EventArgs e)
            {
                // 在新会话启动时运行的代码
                Application.Lock();
                Application["total"] = (int)Application["total"] + 1;
                Application["online"] = (int)Application["online"] + 1;
                Application.UnLock();
            }

            void Session_End(object sender, EventArgs e)
            {
                // 在会话结束时运行的代码。
                Application.Lock();
                Application["online"] = (int)Application["online"] - 1;
                Application.UnLock();
            }
           
    </script>


    运行测试
    5、拖两个Lable 到 Default.ASPx      上;
    6、其Default.ASPx.cs 代码如下:

    public partial class _Default : System.Web.UI.Page
    {
            protected void Page_Load(object sender, EventArgs e)
            {
                this.Label1.Text = "总访问人数" + Application["total"].ToString();
                this.Label2.Text = "当前在线数" + Application["online"].ToString();
            }
    }


    7、OK!!启动调试。

    注意事项

    8、
              我在VS2005中调试进行时,显示:总访问人数为1001;当前在线数1当;
              我重新打开另外一个IE,并把地址Copy过去,这时显示:总访问人数为1002;当前在线数2;
              这说明一切正常。但数据库中仍然为1000,??????
              我就是在这里让耽误了很多的时间(一天),但在我绝望时,我多试了一次,
              然而,这一次上天意给了我意外的恩赐。

              这时,我在VS2005中,"文件"菜单,选择“保存Global”;
              此时,数据库中的1000才更新为1002。
              如果在I I S 中调试也一样,要正常关机或停掉WWW服务才将数据一性写进数据库。

  • 相关阅读:
    MySQL数据库之数据类型
    MySQL数据库之数据操作
    MySQL数据库之表的操作
    十、原子操作
    九、std::async异步线程
    八、条件变量
    cisco笔试记录
    七、单例设计模式
    基于HTTP的功能追加协议
    使用栈来计算后缀表达式
  • 原文地址:https://www.cnblogs.com/bluedy1229/p/1544113.html
Copyright © 2011-2022 走看看