社区
ASP
帖子详情
一个用户登录问题,急哦!!!
liuyong320324
2004-08-04 04:46:08
当一个用户用自己的用户名登录到一个社区的同时,别人在用这个用户名就无法登录,这种功能怎样实现。在这先谢了。
...全文
185
17
打赏
收藏
一个用户登录问题,急哦!!!
当一个用户用自己的用户名登录到一个社区的同时,别人在用这个用户名就无法登录,这种功能怎样实现。在这先谢了。
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
17 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
wangjinmin1982
2004-08-05
打赏
举报
回复
关注最佳解决方案,听听各位的高见,我以前从没想过这个问题
hacker18
2004-08-05
打赏
举报
回复
'查询数据库
……
if not rs.eof then
if rs("online")=1 then
response.write "用户已登录,系统拒绝再次登录。"
response.end
end if
end if
若发生二人(或者是三人、四人……)同时登录、其中一人断线等特殊情况,上述代码可能会失效。
hrstudy
2004-08-04
打赏
举报
回复
看看可否实现你的功能:
http://redftp.vicp.net/bbs/dispbbs.asp?boardID=45&ID=1947&page=1
aiguo25
2004-08-04
打赏
举报
回复
ding
QQ也有这样的功能
weige250
2004-08-04
打赏
举报
回复
up
街头小贩
2004-08-04
打赏
举报
回复
我也是这么作的!
不过我设了在线的时间!当用户在指定的时间内无响应就锁注帐号了!
要作一个解锁的网页!
我在用户的表中加了一个是/否的字段
登陆时为-1,关闭是为0
liuyong320324
2004-08-04
打赏
举报
回复
我用access,不是sql。那怎么办?
begbear
2004-08-04
打赏
举报
回复
那還不如用一個application變量來判斷是否斷電或意外終止。﹖
ycted
2004-08-04
打赏
举报
回复
这个问题我到现在都还没有最好的解决方法.我的方法是:登陆记1,如果再次登陆,第一次输入正确后是提醒有人使用,第二次就是把现在登陆的人踢出来,(也就类似在线自救的方法)
原来到是有人问过这个问题.但我觉得还是有弊端.下面我把想法贴出来.
在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。
可能会有人说在用户信息表中加一字段判断用户工号登录的状态,登录后写1,退出时写0,且登录时判断其标志位是否为1,如是则不让该用户工号登录。但是这样那势必会带来新的问题:如发生象断电之类不可预知的现象,系统是非正常退出,无法将标志位置为0,那么下次以该用户工号登录则不可登入,这该怎么办呢?
或许我们可以换一下思路:有什么东西是在connection断开后可以被系统自动回收的呢?对了,SQL Server的临时表具备这个特性!但是我们这里的这种情况不能用局部临时表,因为局部临时表对于每一个connection来说都是一个独立的对象,因此只能用全局临时表来达到我们的目的。
好了,情况已经明朗话了,我们可以写一个象下面这样简单的存储过程:
create procedure gp_findtemptable -- 2001/10/26 21:36 zhuzhichao in nanjing
/* 寻找以操作员工号命名的全局临时表
* 如无则将out参数置为0并创建该表,如有则将out参数置为1
* 在connection断开连接后,全局临时表会被SQL Server自动回收
* 如发生断电之类的意外,全局临时表虽然还存在于tempdb中,但是已经失去活性
* 用object_id函数去判断时会认为其不存在.
*/
@v_userid varchar(6), -- 操作员工号
@i_out int out -- 输出参数 0:没有登录 1:已经登录
as
declare @v_sql varchar(100)
if object_id('tempdb.dbo.##'+@v_userid) is null
begin
set @v_sql = 'create table ##'+@v_userid+'(userid varchar(6))'
exec (@v_sql)
set @i_out = 0
end
else
set @i_out = 1
在这个过程中,我们看到如果以用户工号命名的全局临时表不存在时过程会去创建一张并把out参数置为0,如果已经存在则将out参数置为1。
这样,我们在我们的应用程序中调用该过程时,如果取得的out参数为1时,我们可以毫不客气地跳出一个message告诉用户说”对不起,此工号正被使用!”
liuyong320324
2004-08-04
打赏
举报
回复
那么这个问题能不能解决啊。
uhopenet
2004-08-04
打赏
举报
回复
关闭浏览器时还好解决,你只要在BODY里利用ONUNLOAD事件调用另一个置0的程序就可以了,但是如果是断电就麻烦了,没有请求啊,下次就没法登陆了
satans18
2004-08-04
打赏
举报
回复
这个问题已经被讨论很多次了~~
好像还没有什么很完美的解决的方法
josney
2004-08-04
打赏
举报
回复
如果online=0那就是离线了吗?
uhopenet
2004-08-04
打赏
举报
回复
josney(梦凌风) :
那你怎么判断用户是否离线了呢
liuyong320324
2004-08-04
打赏
举报
回复
当关闭浏览器,怎样把这个标记置为0啊
wsdzmhongm
2004-08-04
打赏
举报
回复
有这么简单吗?
josney
2004-08-04
打赏
举报
回复
用一个字段online记住就可以了,1为在线,0为不在线,默认为0,登录后更新为1,这样别人要登录时你就判断一下就OK了
请问有关 事务ID的
问题
!!
急
!!
内容:事务ID,
用户登录
成功,会议能力服务器会为该用户创建
一个
事务,并把事务ID返回给会议业务服务器。该用户后续的请求必须携带该事务ID,否则请求无效。该事务具备有时效性,用户注销或一段时间没有活动,事...
tiki登录显示服务器繁忙,tikiwiki安装使用中遇到诸多
问题
。
急
!
急
!
急
!
我在
一个
Linux服务器上安装了tikiwiki3.1版本,在服务器上装的是XAMPP Linux1.7.2版本。其中,Apache 2.2.12, MySQL 5.1.37, PHP 5.3.0 版本,Linux(Red Hat Enterprise Linux AS release 4 (Nahant Update 6)Kernel ...
安装的oracle打不开,关于安装ORACLE 10的
问题
,打不开,
急
!!
关于安装ORACLE 10的
问题
,打不开,
急
!!我今天安装了ORACLE 10,安装的一切顺利,可是我发现安装结束后,我的开始 菜单的程序中没有ORACLE 10的文件夹,那我怎么启动ORACLE 10啊? 我在安装路径下也没找到启动的执行文件,谁...
java访问登录网页_===java怎样访问需要登录才能查看的网页????
急
!!===...
注意:我说的要输入用户名和密码不是浏览器弹出
一个
框的那种,而是象csdn这种,登录后才能发帖子的这种。(大部分网站都是这种方式)|>楼上的,要是我要访问其他需要登录才能查看的页面而不是登录的那个页面呢?>...
别点了!CAS登录对接,这个Bug让你反复登录!
你是否曾经在登录
一个
网站时,不断输入账号密码,却发现自己总是无法成功...今天我要和大家分享的就是CAS登录对接中的
一个
意想不到的Bug,让你不断试错,反复登录。别
急
着点登录按钮,先来看看这个Bug是怎么出现的吧!
ASP
28,391
社区成员
357,059
社区内容
发帖
与我相关
我的任务
ASP
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
复制链接
扫一扫
分享
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章