SQL语句是 :update vod_user set user_line = 0 where name = User.Identity.Name

解决方案 »

  1.   

    但是当系统把某个用户踢出系统时,并没有执行上面的SQL语句;
    好象是在Global.asax.vb中不能使用User.Identity.Name?
      

  2.   

    需要登陆后才可以观看:)我的id:jianghua
        pwd:13617822
      

  3.   

    呵呵, acewang(龍芯*Inside!) 搞笑啊:)
      

  4.   

    ASP.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 id="visitors" 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。这样,我们的程序就可以在不同的访问者环境中顺利运行。 
       
        四、总结 
       
        以上的统计程序特别简单,但是,细节的东西我们不一定想到,这也是我们在编程中需要多一点考虑的。
    function GetMessage()
    {
    var objXMLHTTP = new ActiveXObject("MICROSOFT.XMLHTTP");
        objXMLHTTP.open("GET","footballScore.aspx?" + new Date(), false);  objXMLHTTP.send("");

    var strReturn = objXMLHTTP.ResponseText;

    OnLine_Num.innerHTML = "即时比分:" + strReturn + "<br>上次刷新时间:" + new Date();
    }定时刷新这段函数
      

  5.   

    和ASP一样:下面的放到Global.asax  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(); 
      }
      

  6.   

    如果可能,给我份源码
    [email protected]
    谢谢啊
      

  7.   

    我也讲讲我个人看法吧一,定时刷新的的问题:在ASP.NET中可以利用global.asax 中的 Application_OnStart 事件过程中定义计时器 就可以实现定时执行一个事件(你可以刷新在线列表),System.Timers.Timer二,如果你想 Global.asax.vb中使用User.Identity.Name,可以参考这个http://dev.csdn.net/develop/article/18/18958.shtm
      

  8.   

    1.在线用户列表已经实现:利用在用户通过验证后设定数据库user_line为1,在Session_End 
                          设置数据库user_line为0,通过user_line来显示在线用户列表
    2. webmasterss(天涯解语花):因为是给单位做的,所以不能给你呀:(不过很希望同你讨论技术
                               上的问题:)3. zl9732(zl9732):由于是限制IP的所以注册后指能看免费的影片:)4. lsg2003lsg(天空) :很感谢你的建议:)5.menuvb(为了明天而努力^…) :自动刷新的方法很好,由于'在线用户列表'是提供给管理系统
                                 使用的,所以我还是采用数据库结合Session来实现:)
      

  9.   

    [email protected]
    如果可以的话,参看一下源码.
      

  10.   

    大家有架设过real 服务器的吗,我们单位的real 服务器现在总是出现'缓冲'的现象,是带宽问题还是速率的问题,或是其它方面的;请指点一,二.....