利用HttpModuler实现WEB程序同一时间只让一个用户实例登陆

转载 2006年06月20日 11:19:00
 
/*
作者:阿牛(牛昆亮) QQ:273352165 MSN:niukl@hotmail.com

声明:可以免费使用,请您保留此信息
    如果您有什么改过,记得告诉我!
*/


我在们使用ASP.Net开发WEB网站时,有的时候是不让同一个用户名在同一时间进行多次登陆的。
      为了不影响原来的整个网站,我选择使用了HttpModuler来实现。
 先让所有的Page从自己的Page类:BasePage类继承,并实现 ISigleLogin接口。相关代码如下:

    public interface ISingleLogin
    
{
        
string SigleUserLoginId get; }

        
void SigleUserLogout();

    }

public class BasePage : System.Web.UI.Page , BNet.Web.Modulers.ISingleLogin
{
    
public BasePage()
    
{
        
//
        
// TODO: 在此处添加构造函数逻辑
        
//
    }


    
protected override void OnLoad(EventArgs e)
    
{
        
base.OnLoad(e);
        
if (Session["UserId"== null)
        
{
            Response.Write(
"你还没有登陆");
            Response.Redirect(
"login.aspx");
        }

    }


    
#region ISingleLogin 成员

    
public string SigleUserLoginId
    
{
        
get 
        
{
            
if (Session["UserId"!= null)
            
{
                
return Session["UserId"].ToString();
            }

            
else
                
return "";
        }

    }


    
public void SigleUserLogout()
    
{
        Session.Abandon();
        Response.Write(
"你在别处已经登陆,强制退出本次登陆!");
    }


    
#endregion

}

      然后在Web.config中加入HttpModuler:

<system.web>
    
<httpModules>
      
<add name="SingleLogin" type="BNet.Web.Modulers.SingleLoginModuler"/>

    
</httpModules>
</system.web>
      相关的SigleLoginModuler代码如下:
using System;
using System.Collections.Generic;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.UI;

namespace BNet.Web.Modulers
{
    
/// <summary>
    
/// SingleLoginModuler 的摘要说明
    
/// </summary>

    public class SingleLoginModuler : System.Web.IHttpModule
    
{
        
const string sigle_login_userid = "evlon_siglelogin_userid";
        
const string sigle_pre_logout_sessionid = "evlon_sigle_pre_logout_sessionid";

        
static StringLifeValueDictionary loginedUserIdDictionary = null;
        
static StringLifeValueDictionary LoginedUserIdDictionary
        
{
            
get
            
{
                
if (loginedUserIdDictionary == null)
                
{
                    loginedUserIdDictionary 
= new StringLifeValueDictionary();
                }

                
else
                
{
                    List
<string> listRemove = new List<string>();
                    StringLifeValueDictionary.Enumerator iter 
= loginedUserIdDictionary.GetEnumerator();
                    
while (iter.MoveNext())
                    
{
                        
if (iter.Current.Value.life < DateTime.Now)
                        
{
                            listRemove.Add(iter.Current.Key);
                        }

                    }


                    
foreach (string key in listRemove)
                    
{
                        loginedUserIdDictionary.Remove(key);
                    }

                }


                
return loginedUserIdDictionary;
            }

        }


        
static StringLifeValueDictionary preLogoutSessionIdDictionary = null;
        
static StringLifeValueDictionary PreLogoutSessionIdDictionary
        
{
            
get
            
{
                
if (preLogoutSessionIdDictionary == null)
                
{
                    preLogoutSessionIdDictionary 
= new StringLifeValueDictionary();
                }

                
else
                
{
                    List
<string> listRemove = new List<string>();
                    StringLifeValueDictionary.Enumerator iter 
= preLogoutSessionIdDictionary.GetEnumerator();
                    
while (iter.MoveNext())
                    
{
                        
if (iter.Current.Value.life < DateTime.Now)
                        
{
                            listRemove.Add(iter.Current.Key);
                        }

                    }


                    
foreach (string key in listRemove)
                    
{
                        preLogoutSessionIdDictionary.Remove(key);
                    }

                }


                
return preLogoutSessionIdDictionary;
            }

        }


        
public SingleLoginModuler()
        
{
            
//
            
// TODO: 在此处添加构造函数逻辑
            
//
        }


        
#region IHttpModule 成员

        
public void Dispose()
        


        
public void Init(HttpApplication context)
        
{
            context.PreRequestHandlerExecute 
+= new EventHandler(context_PreRequestHandlerExecute);
            context.PostRequestHandlerExecute 
+= new EventHandler(context_PostRequestHandlerExecute);
            
        }




        
void context_PreRequestHandlerExecute(object sender, EventArgs e)
        
{
            HttpApplication context 
= sender as HttpApplication;
            IHttpHandler httpHandler 
= context.Context.CurrentHandler;
            
if (httpHandler is ISingleLogin)
            
{
                ISingleLogin sl 
= httpHandler as ISingleLogin;
                
string suid = sl.SigleUserLoginId;
                
if (suid != string.Empty)
                
{
                    
if (PreLogoutSessionIdDictionary.ContainsKey(context.Session.SessionID))
                    
{
                        
//这个用户应该强制登出
                        PreLogoutSessionIdDictionary.Remove(context.Session.SessionID);

                        Page page 
= (Page)httpHandler;
                        page.PreInit 
+= new EventHandler(page_PreInit);

                    }

                    
else if (!LoginedUserIdDictionary.ContainsKey(suid))
                    
{
                        LoginedUserIdDictionary.Add(suid, 
new LifeValue(context.Session.SessionID));
                    }

                }

            }


        }


        
void page_PreInit(object sender, EventArgs e)
        
{
            Page page 
= sender as Page;
            ISingleLogin sl 
= page as ISingleLogin;
            
if (sl != null)
            
{
                sl.SigleUserLogout();
                page.Response.End();
            }

        }


        
void context_PostRequestHandlerExecute(object sender, EventArgs e)
        
{
            
//从LogineduserId 里找到和当前用户一样的用户ID的SessionId
            HttpApplication context = sender as HttpApplication;
            IHttpHandler httpHandler 
= context.Context.CurrentHandler;
            
if (httpHandler is ISingleLogin)
            
{
                ISingleLogin sl 
= httpHandler as ISingleLogin;
                
string suid = sl.SigleUserLoginId;
                
if (suid != string.Empty)
                
{
                    
if (LoginedUserIdDictionary.ContainsKey(suid))
                    
{
                        
string sessionId = LoginedUserIdDictionary[suid].value;
                        
if (sessionId != context.Session.SessionID)
                        
{
                            
if (!PreLogoutSessionIdDictionary.ContainsKey(sessionId))
                            
{
                                PreLogoutSessionIdDictionary.Add(sessionId,
new LifeValue(suid));
                            }


                            LoginedUserIdDictionary.Remove(suid);
                        }

                    }

                    
else
                    
{
                        LoginedUserIdDictionary.Add(sl.SigleUserLoginId, 
new LifeValue( context.Session.SessionID));
                    }


                }

            }

        }


        
#endregion

    }


    
public class LifeValue
    
{
        
public string value;
        
public DateTime life;

        
public LifeValue(string value)
        
{
            
this.value = value;
            
this.life = DateTime.Now.AddMinutes(HttpContext.Current.Session.Timeout + 5);
        }

    }


    
public class StringLifeValueDictionary : Dictionary<string, LifeValue>
    
{

    }



    
public interface ISingleLogin
    
{
        
string SigleUserLoginId get; }

        
void SigleUserLogout();

    }

}

java web开发一个帐号同一时间只能一个人登录(单点登录)

对于一个帐号在同一时间只能一个人登录,可以通过下面的方法实现: 1 .在用户登录时,把用户添加到一个ArrayList中 2 .再次登录时查看ArrayList中有没有该用户,如果ArrayList中...
  • qq_24531461
  • qq_24531461
  • 2017年04月28日 17:04
  • 1408

javaweb实现一个账号只能同时被一个人使用(Java实现)

大家在登陆qq的时候,电脑上登陆了qq,如果另一台机器上也登陆该qq账号,那么之前的qq账号会被挤下去。 我们现在用web的方式来做一个非常简单的演示。 先简单的说一下功能吧, 用户只有一个Us...
  • qq_29663071
  • qq_29663071
  • 2017年03月28日 22:33
  • 2184

Java Servlet实现同一账号后登陆挤掉前一个登陆(类似QQ)

实现类似QQ登陆功能,账号已在一处登陆,在另外一处登陆时,将挤掉前一次的登录。 原理简介: 主要是servlet中对用户登录时的处理,servlet中维护了用户和sessionId的关系以...
  • liuyuhua0066
  • liuyuhua0066
  • 2013年04月11日 13:21
  • 3789

利用HttpModuler实现WEB程序同一时间只让一个用户实例登陆(修改)

转自using System;using System.Collections.Generic;using System.Data;using System.Configuration;using S...
  • david_520042
  • david_520042
  • 2011年02月16日 12:45
  • 1012

java web中实现同一帐号同一时间只能一个地点登陆(类似QQ登录的功能)

又有好多天没有写博客了,最近有网友问我,在java web中如何实现像QQ登录的功能,同一帐号不能同时在两台电脑上登录。 一、该功能有什么作用 大家想想吧。反正总会有这样的需求的。这年头什么需求不...
  • kjk7820329
  • kjk7820329
  • 2011年08月30日 13:49
  • 847

java web中实现同一帐号同一时间只能一个地点登陆(类似QQ登录的功能)

一、该功能有什么作用      大家想想吧。反正总会有这样的需求的。这年头什么需求不会有。。呵呵。有时候也不一定是需求,很有可能为了安全也会这么做。例如考试系统,在线聊天系统,很有必要做成这样的吧。...
  • z1321930490
  • z1321930490
  • 2013年08月20日 17:24
  • 705

java web中实现同一帐号同一时间只能一个地点登陆(类似QQ登录的功能)

在java web中如何实现像QQ登录的功能,同一帐号不能同时在两台电脑上登录。 一、该功能有什么作用      大家想想吧。反正总会有这样的需求的。这年头什么需求不会有。。呵呵。有时候也...
  • StarLOVELeaf
  • StarLOVELeaf
  • 2017年06月07日 17:41
  • 388

java实现统一账户同一时间只能在一个地方登陆

现在所做的手机软件要求类似QQ,当一处登陆.另外一处就要取消.所以查看了一下源代码.发现代码实现如下 web.xml:实现监听session作用.一旦session出现登陆、重复登录或者超时等.调用...
  • ss19871028
  • ss19871028
  • 2013年05月27日 21:01
  • 1201

如何用Qt写一个同一时间只能运行一个实例的应用程序

http://blog.sina.com.cn/s/blog_6343941a0100nk2x.html   为了使一个应用程序在同一时间只运行一个实例,需要用某种方法在程序启动时,检测是否已有正在运...
  • xj626852095
  • xj626852095
  • 2013年08月29日 16:55
  • 1083

java web实现同一账号同一时间只能在一个地方登录

网上看了很多方法,个人也看了,自己也总结了几个比较常用的:           前提都是用session监听器,对session的创建与销毁进行监听       一、在用户登录时保存该用户的状态有...
  • idleneedy
  • idleneedy
  • 2012年12月29日 13:03
  • 2256
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:利用HttpModuler实现WEB程序同一时间只让一个用户实例登陆
举报原因:
原因补充:

(最多只允许输入30个字)