很多网友都问如何制作社区的在线人员显示问题,这也是个老大难的问题。由于笔者已经学习和实践了这些方面的编程已经有很长一段时间了。不说是有技术,也算是有些经验了,在这些问题解决方面我也曾遇到比较多的问题,后来总是解决了。   
    这次和大家讲的不关是一个程序的代码实现,而更重要的就是一个原理和思想问题,因为如何大家都知道这个该如何去做的话,就不存在技术上的难题了,而只是一个语法上的不熟罢了。   
    其实判断用户是否登录很简单,只要在登录的程序加上   "把用户设为在线"   就行了,这可以用SQL的update来做也可以用其他的如对文本文件的追加来做。如何登录时是设置的可以COOIKE登录的话,你只要在浏览页面或是发表贴子等的页面,进行更新也可以。   
    其实网友认为难的就在于如何知道用户已经离开社区了。下面有几个初学网友会犯的错误。   
    错误方法一:   当然有的网友会做在社区里做个   "退出社区"   可有的用户比较忙或是手比较快,就会直接的关闭浏览器了。那么在程序看来此用户根本就没有退出社区。   
    错误方法二:   为了这样也有的网友以关闭浏览器为标准,例如每当用户直接关闭浏览页面时,用JavaScript执行一个unload事件,跳出一个窗口,来执行相就在的更新,这也许是解决直接关闭的问题。可是网友没有考虑到如果因为贴子或文章太长,用户想断了线后,再好好的看看,那么他正好是直接断线后,看完所有贴子或文章再关闭浏览器的呢。此时跳出窗口页面的程序就等于没有执行。   
    错误方法三:使用session为例,一般的服务器中都有Session的失效时间,如IIS中为20分钟,有的网友以Session为标准,来判断,这显然也是行不通的,结果会和错误方法二一样。   
    那么如果才是正确的方法呢。到现在为此还没有一种方便的和精确的方法,除非你用Job事务来做,当那几乎是不可能的,因为免费的,即使是收费的主页空间也不会让你这么做的。所以只能能过普通的命令来实现了。     
  不过它的局限性就在于不能精确,但是我们可以让他更加的接近于精确。   
  下面我们会以IIS环境下的SQL   SERVER服务器为例子。其他的如PHP+MYSQL,JSP+MS   SQL   SERVER等举一反三,几乎语句都不用怎么变。   
    例子中采用程序片段,例如用户在表users中,除了基本要有的用户名字段(name)等,要有online字段,可以用bit类型就可以了。还要有一个登录时间的字段logintime,和***操作时间的字段logouttime,都为datetime类型。详细的作用我们会在后面谈到。   
    首先在用户登录进入时,要生成一个Session("name")字段的值,或是cookies("club")("name")的值,以便于在进行操作时,让SQL在社区中任意页面都知道是哪个用户的记录。接着更新用户的下online字段和logintime字段,语句如下:   
    conn.execute("Update   users   set   online=1,logintime='"&now&"'   where   name='"&session("name")&"'")   
    这条语句的作用在于当用户登录时,就把用户在线设为真,再把当前操作时间设为现在。其次在用户进行贴子或文章浏览时,也要用此语句,因为这样才可能更加的准确些。   
  在这些语句的后面再加上一句。   
    conn.execute("Update   users   set   online=0   where   diffdate(""n"",logintime,'"&now()&"')>10")     
    这条语句的作用表示把用户***操作时间和当前时间相比较,如果大于10分钟的话,就会把这些用户都设为离线。   
    好了,其实关键的也就是这两条语句而以,是不是很简单?说了这么多,其实想让大家了解的就是实现的原理,而不是什么代码。相信大家现在也可以很简单的做出关于PHP+MYSQL和JSP+数据库的在线人员显示的程序来了。   
    ***可以用"select   name   from   users   where   online=1"来调用在线的用户了,然后显示出来当然也没问题了。呵。。。

***************************
namespace OnlineCount
{
using System;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
///
///Online 的摘要说明。
/// 
public class Online : System.Web.UI.UserControl
{
protected System.Web.UI.WebControls.Label Label1; 
private void Page_Load(object sender, System.EventArgs e)
{
if (Application["online"] == null)
{
DataTable dtnew = new DataTable();
dtnew.Columns.Add("userid",typeof(string));
dtnew.Columns.Add("lastaccesstime",typeof(DateTime));
Application["online"] = dtnew;
} 
//DataTable dt = (DataTable)Application["online"];
DataTable dt = Application["online"] as DataTable;
DataRow[] rows = dt.Select("userid='"+Session.SessionID+"'");
if (rows.Length == 1)
{
DataRow dr = rows[0];
dr["lastaccesstime"] = DateTime.Now;
}
else
{
DataRow dr = dt.NewRow();
dr["userid"] = Session.SessionID;
dr["lastaccesstime"] = DateTime.Now;
dt.Rows.Add(dr);
}
for(int i = 0 ; i < dt.Rows.Count; i++)
{
DataRow dr = dt.Rows[i];
TimeSpan t = DateTime.Now - Convert.ToDateTime(dr["lastaccesstime"]);
if (t.Seconds > 8)
{
dr.Delete();
}
}
dt.AcceptChanges(); 
this.Label1.Text = dt.Rows.Count.ToString();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
} 
/// 
///设计器支持所需的方法 - 不要使用代码编辑器
///修改此方法的内容。
/// 
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load); 
}
#endregion
}
} 
*********** OnlineUser.java ************
package org.sunxin.lesson.jsp.ch09.online;
import javax.servlet.*;
import java.io.*;
import javax.servlet.http.*;
import java.util.Enumeration; 
public class OnlineUser extends HttpServlet
{
    public void doGet(HttpServletRequest req, HttpServletResponse resp)
               throws ServletException,IOException
    {
        req.setCharacterEncoding("gb2312");
        String name=req.getParameter("user");
        String pwd=req.getParameter("password");
            
        if(null==name || null==pwd || name.equals("") || pwd.equals(""))
        {
            resp.sendRedirect("login.html");
        }
        else
        {
            HttpSession session=req.getSession();
            User user=(User)session.getAttribute("user");
            if(null==user || !name.equals(user.getName()))
            {
                user=new User(name);
                session.setAttribute("user",user);
            }
            
            resp.setContentType("text/html;charset=gb2312");
            PrintWriter out=resp.getWriter();
            
            out.println("欢迎用户
"+name+"登录");
            UserList ul=UserList.getInstance();
            out.println("
当前在线的用户列表:
");
            Enumeration  enums=ul.getUserList();
            int i=0;
            while(enums.hasMoreElements())
            {
                out.println(enums.nextElement());
                out.println("    ");
                if(++i==10)
                {
                    out.println("
");
                }
            }
            out.println("
当前在线的用户数:"+i);
            out.println(" 
 退出登录"); 
            out.close(); 
        } 
    } 
     
    public void doPost(HttpServletRequest req, HttpServletResponse resp) 
               throws ServletException,IOException 
    { 
        doGet(req,resp); 
    } 
} 
*********** LogoutServlet.java ************
package org.sunxin.lesson.jsp.ch09.online;
import javax.servlet.*; 
import java.io.*; 
import javax.servlet.http.*; 
public class LogoutServlet extends HttpServlet 
{ 
    public void doGet(HttpServletRequest req, HttpServletResponse resp) 
               throws ServletException,IOException 
    { 
        resp.setContentType("text/html;charset=gb2312"); 
         
        HttpSession session=req.getSession(); 
        User user=(User)session.getAttribute("user"); 
        session.invalidate(); 
         
        PrintWriter out=resp.getWriter(); 
        out.println(""); 
        out.println(user.getName()+",你已退出登录 
"); 
        out.println(" 重新登录"); 
        out.println(""); 
        out.close(); 
    } 
} 
*********** User.java ************
package org.sunxin.lesson.jsp.ch09.online;
import javax.servlet.http.HttpSessionBindingListener; 
import javax.servlet.http.HttpSessionBindingEvent; 
public class User implements HttpSessionBindingListener 
{ 
    private String name; 
    private UserList ul=UserList.getInstance(); 
     
    public User() 
    { 
    } 
    public User(String name) 
    { 
        this.name=name; 
    } 
    public void setName(String name) 
    { 
        this.name=name; 
    } 
    public String getName() 
    { 
        return name; 
    } 
    public void valueBound(HttpSessionBindingEvent event) 
    { 
        ul.addUser(name); 
    } 
    public void valueUnbound(HttpSessionBindingEvent event) 
    { 
        ul.removeUser(name); 
    } 
} 
*********** UserList.java ************ 
package org.sunxin.lesson.jsp.ch09.online; 
import java.util.Vector; 
import java.util.Enumeration; 
public class UserList 
{ 
    private static final UserList userList=new UserList(); 
    private Vector  v; 
     
private UserList() 
{ 
    v=new Vector (); 
} 
public static UserList getInstance() 
{ 
return userList; 
} 
     
    public void addUser(String name) 
    { 
        if(name!=null) 
            v.addElement(name); 
    } 
     
    public void removeUser(String name) 
    { 
        if(name!=null) 
            v.remove(name); 
    } 
     
    public Enumeration  getUserList() 
    { 
        return v.elements(); 
    } 
     
    public int getUserCount() 
    { 
        return v.size(); 
    } 
} 
**************************** 
Java代码的思路是将所有登陆用户放到集合中。 
用户登陆成功就添加到用户列表,用户退出就从用户列表中移出。 
lz 注意User类所实现的接口以及其中以下两个方法:
    //对象被绑定到session中时通知该对象 
    public void valueBound(HttpSessionBindingEvent event) 
    { 
        ul.addUser(name); 
    } 
    //从session中删除对象时通知该对象 
    public void valueUnbound(HttpSessionBindingEvent event) 
    { 
        ul.removeUser(name); 
    } 
                网页名称:在JSP或Servlet中获取session数量
                
                URL分享:http://www.csdahua.cn/qtweb/news21/392921.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网