如何限制同一用户名同时登陆

2016-02-19 12:06 29 1 收藏

下面,图老师小编带您去了解一下如何限制同一用户名同时登陆,生活就是不断的发现新事物,get新技能~

【 tulaoshi.com - Web开发 】

这个问题我的办法是,用户有个活跃时间间隔问题。超过这个活跃时间间隔的则可以认为是离线,后者可以登陆 ,如果无后者登陆,但并不是说前者就需要重新登陆了。因为他的session还在的。只能是这个时间设置的越小越精确,也是不能做到绝对的。
代码贴出来给楼主参考下。
Function CheckOnline()DIM IP,rsPrv,Sql,PrvDbStatePrvDbState = FalseIf DBSTATE = False ThenDbOpen()PrvDbState = TrueEnd IfSet rsPrv=Server.CreateObject("ADODB.Recordset")If Session("UserName") = "" thenSql="select * from [Online] where SessionID='"& Session.Sessionid &"'"rsPrv.Open Sql,Conn,1,3If rsPrv.Eof thenrsPrv.AddNewrsPrv("SessionID") = Session.SessionIDrsPrv("GroupChargeLv") = -1rsPrv("LastActTime") = Now()rsPrv("UserIP") = GetIPrsPrv("OnLineTime") = 0rsPrv("UserWhere") = Request.ServerVariables("HTTP_REFERER")ElsersPrv("UserWhere") = Request.ServerVariables("HTTP_REFERER")rsPrv("OnLineTime") = rsPrv("OnLineTime") + DateDiff("n",rsPrv("LastActTime"),Now())rsPrv("LastActTime") = Now()End IfrsPrv.UpdatersPrv.Close()'response.Write "notlogin"Else'response.Write "logined"Sql="select * from [Online] where UserName='"& Session("UserName") &"'"rsPrv.Open sql,Conn,1,3If rsPrv.Eof thenrsPrv.AddNewrsPrv("SessionID") = Session.SessionIDrsPrv("UserName") = Session("UserName")rsPrv("GroupChargeLv") = Session("GroupChargeLv")rsPrv("LastActTime") = Now()rsPrv("OnLineTime") = 0rsPrv("UserIP")= GetIPrsPrv("UserWhere") = Request.ServerVariables("HTTP_REFERER")ElseIf rsPrv("SessionID")  Session.SessionID And Application("LoginSet")(1) = False ThenInfoTo "LoginOut.asp","该帐户已在其他地方登陆,网站设置1个ID只能有1个登陆n你可以稍候尝试登陆。"Response.End()End IfrsPrv("UserWhere") = Request.ServerVariables("HTTP_REFERER")rsPrv("OnLineTime") = rsPrv("OnLineTime") + DateDiff("n",rsPrv("LastActTime"),Now())rsPrv("LastActTime")=Now() End IfrsPrv.UpdatersPrv.Close()End IfSet rsPrv = NothingIf DateDiff("s",Application("OnLineLastDelete"),Now())  Int(Application("DELETEONLINEDIFF")) ThenApplication.Lock()Application("OnLineLastDelete") = nowApplication.UnLock()Conn.ExeCute("delete from [Online] where datedIff('s',LastActTime,Now())"&Int(Application("CHECKONLINEDIFF") &"")) '删除x秒没有活动的访客End IfIf PrvDbState = True Then DbClose()End Function

来源:https://www.tulaoshi.com/n/20160219/1599832.html

延伸阅读
标签: Web开发
html head style body         { font-size: 10pt; background-color:#D4D0C8 } td           { font-size: 9pt } /style /head script language="javascript" /* 程序标题:javascr...
标签: Web开发
验证注册用户名必须为字母,或者字母+数字,或者全中文,字母是3-20个字符,中文是3-10个 [Ctrl+A 全选]
标签: Web开发
代码如下: //检测用户名是否被占用 function GetO(){ var ajax=false; try { ajax = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { ajax = new ActiveXObject("Microsoft.XMLHTTP"); } catch (E) { ajax = false; } } if (!ajax && typeof XMLHttpRequest!='undefined') { ajax = new XMLHttpRequest(); } retur...
标签: 电脑入门
为便于大家记忆,可以拿公司简称加个人姓名缩写作为大家的用户名,用姓名缩写加公司的电话号码作为各用户的密码。听上去好像挺麻烦,但是用WPS Office 2013 表格完成这一任务就非常简单。 详细制作步骤如下: 1、首先,新建一个工作簿,在sheet1中输入各列标题及其他信息。如图1所示 图1 2、接下来,就要来生成用户名列和密码啦!单击D2...
标签: 电脑入门
知道怎么去掉iis的登录用户名和密码吗? 方法: 安装了iis之后,打开默认网站 http://localhost/ 时弹出一个登陆窗口要求输入用户名和密码解决办法。 开始-运行-gpedit.msc-回车。 计算机配置--管理模板-windows 组件-Internet Exporer-Internet控制面板-安全页-Internet区域:双击登陆选项;选择已启用;登陆选项-自动使用当前用户名和密...

经验教程

679

收藏

18
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部