加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > Asp教程 > 正文

同一个帐号无法同时登陆的问题

发布时间:2023-04-22 14:22:37 所属栏目:Asp教程 来源:
导读:〓简介〓

有点常识的人都知道本身用asp做这种功能显然有些牵强,因为他不像qq,msn或irc 聊天室那样是即时通讯,他都是靠刷新网页更改最后活动时间来获取用户是否在线的,所以您不要指望下面这片教程有多完美,我
〓简介〓
 
有点常识的人都知道本身用asp做这种功能显然有些牵强,因为他不像qq,msn或irc 聊天室那样是即时通讯,他都是靠刷新网页更改最后活动时间来获取用户是否在线的,所以您不要指望下面这片教程有多完美,我也只是把我的思维模式记录下来,有啥不对的地方还请高手们多多指教!
 
〓正文〓
 
首先我先向大家介绍一下我实现这个效果的思路,如果你看过我的思路后就能理解完全没必要将这篇东西看完……
 
实现这个功能我只能想到两种方式来实现:
 
1。数据库+asp
 
做起来可能会复杂些,但是适合有大量登陆用户的系统里。
 
2。application
 
用application对象:如果你做的是大型社区,你可能要为每个登陆id生成一个appliaction,这样做虽然程序上设计会简单些但登陆用户过多及其耗费服务器资源,我这里决不提倡,因为appliaction对象在用户登陆时生成很容易但是要做到真正的随着用户退出系统完全释放掉,到目前我还没看到更好的方法~
 
因此还是让我们来看看用数据库+asp是如何实现同一个帐号不能同时登陆的问题的吧!
 
首先问用户建立数据库这里我们用access新建一个onlyNet118.mdb
 
数据表1: users 存放用户注册资料
 
下设数据表:uID(自动编号) userName(字符型) userPass(字符型)
 
数据表2: onlyLogin 存放用户临时登陆信息
 
下设数据表: OLname(字符型) OLtime(日期型) OLip(字符型)
 
数据库建好后我们直接向users表中手动添加数据 userName表添加Net118,userPass表里添加111,为了能突出我们本文讨论的重点,去掉不必要的废话,所以密码也不要加密了,用户名也自己添加~哈哈~
 
好了,现在数据库里面有用户数据库,下面我们来做用户登陆界面,复制下面代码存成onlyLogin.asp文件。
 
<html>
 
<head>
 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
 
<title>Net118.COM禁止同一账号不同地区同时登陆</title>
 
</head>
 
<body>
 
<form name="form1" method="post" action="loginPost.asp">
 
用户名:<input name="userName" type="text" id="userName" size="15" maxlength="5">
 
密码:<input name="userPass" type="password" id="userPass" size="15" maxlength="15">
 
<input type="submit" name="Submit" value="Login">
 
</form>
 
</body>
 
</html>
 
完成后在新建一个loginCONN.asp文件复制下面的代码保存!是连接数据库的,这个我就不多解释了……
 
<%
 
Dim CONN_Net118
 
Dim Conn_T
 
Dim mmdd
 
mmdd="onlyNet118.mdb"
 
Set CONN_Net118 = Server.CreateObject("ADODB.Connection")
 
Conn_T="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(""&mmdd&"")
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章