如何解决如何在 PHP 或 Laravel 中检测从另一台设备登录?
让我们假设 我在 example.com 上有我的示例帐户。当我登录时,它应该保存我的设备以备下次我回来登录时验证我和我的设备。不管它是什么浏览器,意思是当我第一次做的时候,我用的是 Chrome,现在我在 Firefox 上这样做。
但是有人拿到了我的信用证,或者我自己给了某人信用证,他尝试登录我的帐户,然后它应该会检测到他的新设备。
解决方法
在浏览器中检查您的 cookie 标识符(例如,logged = hash(user_id) 等)。如果它不存在,则意味着它是一个新设备。因此,您可以采取行动,同时将您的标识符存储在浏览器 cookie 中。
编辑:在我的旧项目中,我是这样解决的:
const COOKIE_NAME = "device_code";
public function login()
{
$cookieValue = bcrypt(auth()->id());
if (request()->cookie(self::COOKIE_NAME) != $cookieValue) {
// new device
// do some stuff
// if allowed save cookie
request()->cookie(self::COOKIE_NAME,$cookieValue,$minutes = 60 * 24 * 30);
return $response;
}
// do login logic
return $response;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。