博客封面

php实现不能同时登陆

web安全一直是多向的问题,服务器安全、代码安全等等,本文介绍为php开发的web,如何用php实现一个账号不能多个用户同时登陆 。




思路:

1、每个人登录的时候会生成一个随机码(随机码保存在数据库中);
2、客户端cookies不保存用户名,只保存随机码;
3、账号在任何的地方登录时便会执行第一二部,之前的登录就会失效;
4、功能即可实现;

扩展:
5、可以设置网页最后更新的时间,并且超过一定的时间后就过期;
6、随机码要长一点才不会重复,我现在用的64进制32位,这样几乎不可能重复;
7、另外客户端不保存用户名和密码只存存随机码相对来说安全性也要高些;

解析:

1、使用的是mysql,新增Person_yanzheng字段

2、随机码生成,百度一下很多,本文列举如下:

    function GetRandStr($length) {
        $str = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
        $len = strlen($str) - 1;
        $randstr = '';
        for ($i = 0; $i < $length; $i++) {
            $num = mt_rand(0, $len);
            $randstr .= $str[$num];
        }
        return $randstr;
    }
    $number = GetRandStr(6);
    echo $number;

文中因为使用的是thinkphp,把代码放到了CommonAction控制器中,IndexAction控制器login方法引用即可。

3、action中登陆模块代码,本文以thinkphp为例(登陆模块继承上级CommonAction):

4、CommonAction中代码(yanzheng这个方法是为了验证是否登陆对所有方法都起效果,所有嵌入到这个方法最佳。):

5、这样就可以了。



zhn 发表于 2020-04-02 16:17:00


博客评论

    当前无评论!

留下您的点评:

验证码