本文实例讲述了PHP实现会员账号单唯一登录的方法。分享给大家供大家参考,具体如下:
情景再现
同一会员账号限制在同一台设备(电脑、手机、Ipad等)上单点登录,重复登录后,原登录访问页面时则直接跳转到登录页面且需要重新登录才能正常访问。
原理分析
A账号在A电脑上登录后,A账号此时又用B电脑再次登录,则A电脑请求页面时,提示“重新登录”的信息,并跳转到登录页面
思路解析:
A账号在A电脑上登录后,把SESSION ID写入TXT文件,每次访问页面时,都做一次校验(比较txt文件的值是否和当前登录的session_id的值相同)
实例
1、入口与校验(index.php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
<?php session_start(); $uid = 10; if (is_login( $uid )){ header( 'location:loginSuccess.php' ); } else { $getLogSessionId = file_get_contents ( './upload/session_log/' . $uid . '.txt' ); if ( $getLogSessionId ){ echo "已在其他地方登录,请重新登录" ; echo "<br>" ; echo "5秒后跳转到登录页面!" ; header( "refresh:5;url=login.php" ); } else { echo '第一次登录...' ; echo "<br>" ; echo "3秒钟后跳转到登录页面!" ; header( "refresh:3;url=login.php" ); } } /** * 通过登录时写入文件session_id和当前登录设备后生成的session_id进行比较,相同则是同一台设备登录,不同则在别的地方登录 */ function is_login( $uid ){ $getLogSessionId = file_get_contents ( './upload/session_log/' . $uid . '.txt' ); if ( $getLogSessionId == session_id()){ return true; } else { return false; } } |
2、登录(login.php)
1
2
3
4
5
6
7
|
<?php session_start(); echo "登录中...." ; echo '<br>' ; $uid = 10; file_put_contents ( 'session_log/' . $uid . '.txt' ,session_id()); echo "登录完成" ; |
3、登录成功(loginSuccess.php)
1
2
|
<?php echo "我登录成功了!" ; |
4、保存sessionId文件夹(session_log),测试代码,需要手动建一个或者赋予自动生成文件的权限
摘自PHP会员账号唯一登录的方法分析