zoukankan      html  css  js  c++  java
  • 利用HttpModuler实现WEB程序同一时间只让一个用户实例登陆

     
    /*
    作者:阿牛(牛昆亮) 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();

        }

    }

  • 相关阅读:
    nginx配置zabbix下setup.php(web页面)无法显示,浏览器无法打开
    CentOS release 6.5下jdk1.7升级到1.8
    tcp流量控制
    图像处理服务器
    muduo rpc protobuf 实现学习
    p2p nat 穿透原理
    博客-livevent-stl-cpp-nginx
    使用eventfd创建一个用于事件通知的文件描述符
    多线程设计的类的思考!
    ftp协议服务器与tinyhttp服务demo
  • 原文地址:https://www.cnblogs.com/honker/p/3774466.html
Copyright © 2011-2022 走看看