阅读内容 

signlog 登陆实现

[日期:2005-04-10] 来源:中国站长学院  作者:郁郁小蝎 [字体: ]

关于重新登陆!
1:在Global中的设置。
? //添加Init,并且添加AcquireRequestState事件;
? public void Init(HttpApplication application)
? {
?? application.AcquireRequestState +=new EventHandler(application_AcquireRequestState);
??
? }
? //实现AcquireRequestState,在每次客户端response的时候都会执行这个事件;
? private void application_AcquireRequestState(object sender, EventArgs e)
? {
?? System.Web.HttpApplication App = ((HttpApplication)sender);
?? if(App.Context.Session == null) return;
?? if(App.Context.Session["userID"] == null ) return;
?? System.Data.DataTable dt = (System.Data.DataTable)Application["userTable"];
?? if(dt.Select("userID = "+Session["userID"].ToString()).Length>0)
?? {
??? dt.Rows[0]["loginTime"] = System.DateTime.Now;
??? dt.AcceptChanges();
?? }
??

? }
?
? //Timer的间隔时间?
? private int interval = 20;
?
? //在Application_Start中? 1:建立在线全局用户表; 2:注册timer事件(用于间隔一定时间来维护在线用户表)。
? protected void Application_Start(Object sender, EventArgs e)
? {
?? //--1 application user table;
?? System.Data.DataTable dt = new DataTable();
?? dt.Columns.Add("userID");
?? dt.Columns.Add("loginTime");
?? dt.PrimaryKey = new System.Data.DataColumn[]{dt.Columns["userID"]};
?? dt.AcceptChanges();
?? Application.Lock();
????????????? Application["userTable"] = dt;
?? Application.UnLock();
?? //--2 Timer
?? System.Timers.Timer tm = new System.Timers.Timer();
?? tm.Interval = 60000*this.interval;
?? tm.Elapsed +=new System.Timers.ElapsedEventHandler(tm_Elapsed);
?? tm.Start();
??????
? }
?
? //timer事件;?
?private void tm_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
? {
?? deleteTimeOutUser();
? }
? //删除过期的在线用户;?
?private void deleteTimeOutUser()
? {
?? if(Application["userTable"] == null) return;
?? System.Data.DataTable dt = (System.Data.DataTable)Application["userTable"];
?? foreach(System.Data.DataRow dr in dt.Rows)
?? {
??? if(System.DateTime.Compare(((System.DateTime)dr["loginTime"]).AddMinutes(2),System.DateTime.Now)<0)
???? dr.Delete();
?? }
?? dt.AcceptChanges();
??
? }
//------------------------------用户单击退出后--的过程-----------------------------------------
//退出???????
public void reLogin(System.Web.UI.Page currentPage)
{
?if((currentPage.Session != null)&&(currentPage.Session["userID"] != null))
?{
? this.deleteUser(int.Parse(currentPage.Session["userID"].ToString()),currentPage.Application);
?}
?
?currentPage.Session.Abandon();
?
}

//删除当前用户在application中的userID;
private void deleteUser(int userID,System.Web.HttpApplicationState Application)
{
?if(Application["userTable"] == null) return;
?System.Data.DataTable dt = (System.Data.DataTable)Application["userTable"];
?foreach(System.Data.DataRow dr in dt.Rows)
?{
? if(int.Parse(dr["userID"].ToString()) == userID)
?? dr.Delete();
?}
?dt.AcceptChanges();

}

在删除在线用户时如果程序使用了Form认证模式,还应该System.Web.Security.FormsAuthentication.Signout()

----------------------------------------------------------------------------
遗留问题,虽然解决了超时注销的问题,但用户直接退出IE时如何向服务器发出 退出请求,删除当前用户ID;

?

阅读:
录入:

推荐 】 【 打印
相关新闻      
本文评论       全部评论
发表评论
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款


点评: 字数
姓名:
Advertisement
内容查询


Advertisement