废话不多说,直接搞
思路:member表中增加一个记录sessionid的字段,每次登录时获取之前的sessionid,先清除再登录
数据表中member增加字段,字段名:session_id,TEXT,长度50
修改文件:apps/home/model/membermodel.php
在:
// 会员注册
public function register($data)
上方添加一下代码
public function get_session_id($where)
{
$field = array(
'a.session_id'
);
$user = parent::table('ay_member a')->field($field)
->where($where)
->find();
return $user->session_id;
}
public function update_session($userid,$session_id)
{
$data = array(
'session_id' => $session_id
);
// 更新登录信息
parent::table('ay_member')->where('id=' . $userid)->update($data);
// return $user;
}
修改文件:apps/home/controller/membercontroller.php
找到如下代码
// 登录验证
if (! ! $login = $this->model->login("(username='$username' or useremail='$username' or usermobile='$username') AND password='$password'")) {
在上方添加
if (! !$old_session_id = $this->model-> get_session_id("(username='$username' or useremail='$username' or usermobile='$username') AND password='$password'")){
if (file_exists(RUN_PATH . '/session/'.$old_session_id[0].'/'.'sess_' . $old_session_id)){
unlink(RUN_PATH . '/session/'.$old_session_id[0].'/'.'sess_' . $old_session_id);}
};
找到如下代码
session('pboot_uid', $login->id);
session('pboot_ucode', $login->ucode);
在上方添加如下代码
$this->model->update_session($login->id,session_id());
至此修改完成,用两个浏览器测试下,完美!思路仅供参考,有更好解决办法欢迎交流