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

简介:

/*http://evlon.cnblogs.com/archive/2006/03/20/354191.html
*/


我在们使用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");
        }

    }


    
ISingleLogin 成员
}

      然后在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: 在此处添加构造函数逻辑
            
//
        }


        
IHttpModule 成员
    }


    
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();

    }

}



本文转自高海东博客园博客,原文链接:http://www.cnblogs.com/ghd258/archive/2006/03/21/354569.html,如需转载请自行联系原作者
相关文章
|
1月前
|
安全 测试技术 数据库
维护的Web应用程序
【10月更文挑战第4天】维护的Web应用程序
47 4
|
25天前
|
数据可视化 数据库 开发者
使用Dash构建交互式Web应用程序
【10月更文挑战第16天】本文介绍了使用Python的Dash框架构建交互式Web应用程序的方法。Dash结合了Flask、React和Plotly等技术,让开发者能够快速创建功能丰富的数据可视化应用。文章从安装Dash开始,逐步介绍了创建简单应用程序、添加交互元素、部署应用程序以及集成更多功能的步骤,并提供了代码示例。通过本文,读者可以掌握使用Dash构建交互式Web应用程序的基本技巧和高级功能。
41 3
|
1月前
|
JavaScript 前端开发
如何使用Vue.js构建响应式Web应用程序
【10月更文挑战第9天】如何使用Vue.js构建响应式Web应用程序
|
1月前
|
前端开发 JavaScript 测试技术
构建响应式Web应用程序:React实战指南
【10月更文挑战第9天】构建响应式Web应用程序:React实战指南
|
1月前
|
存储 JavaScript 前端开发
如何使用React和Redux构建现代化Web应用程序
【10月更文挑战第4天】如何使用React和Redux构建现代化Web应用程序
|
1月前
|
设计模式 测试技术 持续交付
开发复杂Web应用程序
【10月更文挑战第3天】开发复杂Web应用程序
39 2
|
1月前
|
SQL 安全 测试技术
漏洞扫描技术:对Web应用程序进行漏洞扫描
漏洞扫描技术:对Web应用程序进行漏洞扫描
|
1月前
|
云安全 SQL 安全
数字时代下的Web应用程序安全:漏洞扫描服务的功能与优势
在当今这个数字化时代,Web应用程序不仅是企业与用户之间互动的桥梁,更是企业展示服务、传递价值的核心平台。然而,随着技术的不断进步,Web应用程序的复杂性也在不断增加,这为恶意攻击者提供了可乘之机。安全漏洞的频发,如SQL注入、跨站脚本攻击(XSS)、跨站请求伪造(CSRF)等,严重威胁着企业的数据安全、服务稳定性乃至经济利益。在这样的背景下,漏洞扫描服务作为一道重要的安全防线,显得尤为重要。本文将深入探讨漏洞扫描服务在面对Web应用程序安全问题时,所具备的功能优势。
|
1月前
|
安全 Java Linux
Kali渗透测试:通过Web应用程序实现远程控制
Kali渗透测试:通过Web应用程序实现远程控制
|
1月前
|
存储 缓存 安全
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
32 0
下一篇
无影云桌面