QQ가 다른 곳에서 로그인하면 메시지 알림이 표시됩니다. 보안 요구 사항이 상대적으로 높은 웹 사이트, 특히 백엔드 관리의 경우 계정이 도난당했는지 또는 다른 사람이 로그인했는지 확인해야 할 때가 있습니다. 두 사람이 동시에 로그인하고 작업하는 것을 방지하기 위해 백그라운드 작업을 수행하는 것은 매우 안전하지 않습니다.
물론 IP는 특정 네트워크 세그먼트 내에서 언제든지 변경되기 때문에 IP로 판단할 수는 없지만, 이 문제를 해결할 수 있는 메커니즘이 있는데, 그것이 바로 동일한 브라우저를 사용하는 한입니다. 웹 사이트에 액세스하기 위해 브라우저는 변경되지 않습니다. 각 방문자의 session_id는 변경되지 않으며 이는 바로 이 문제를 해결하는 데 필요한 것입니다.
TP 프레임워크로 구축한 웹사이트 백엔드를 예로 들어 보겠습니다. 아이디어는 다음과 같습니다.
(1) 데이터베이스 사용자 테이블
사용자 테이블에 `session_id` varchar(32) 필드를 추가합니다.
, 로그인 후 session_id를 저장하는 데 사용됩니다. `session_id` varchar(32)
,用来存放登录之后的session_id。
(2)用户登录
用户登录,就是正常的判断账号密码以及验证码,当这些都验证通过的时候,取出当前的session_id存入数据库user表中。
M('user')->where(array('id'=>$_SESSION['uid']))->save(array('session_id'=>session_id()));
(3)解决异地登录问题
对于后台操作,为了便于验证和操作安全,基本都会先创建一个基础控制器BaseController,然后后台的其他操作控制器都继承这个基础控制器。对于后台的每一步操作之前,用户状态的检测都放在BaseController控制器的初始化_initialize()
方法中。
现在在_initialize()
(2) 사용자 로그인
사용자 로그인은 계정 비밀번호와 인증 코드가 정상적으로 확인되면 현재 session_id를 꺼내어 데이터베이스의 사용자 테이블에 저장합니다.
$user = M('user')->where(array('id'=>$_SESSION['uid']))->find(); $session_id = session_id(); if($user['session_id'] != $session_id){ session_destroy(); $this->error('您的账号在其他地方登录,您已经被强制下线', U('login')); }
백그라운드 작업의 경우 검증 및 작업 보안을 용이하게 하기 위해 기본적으로 기본 컨트롤러인 BaseController가 먼저 생성되고 백그라운드의 다른 작업 컨트롤러가 상속됩니다. 이 기본 제어 장치. 백그라운드 작업의 각 단계 전에 사용자 상태 감지는 BaseController 컨트롤러의 초기화 _initialize()
메서드에 배치됩니다.
이제 _initialize()
메소드에서는 사용자 로그인 상태가 잠겨 있는지 등을 확인하는 것 외에도 로컬 session_id를 꺼내어 사용자 테이블에 저장된 session_id와 비교해야 합니다. 일치하지 않으면 해당 테이블 이름을 가진 계정이 다른 위치에 로그인됩니다. 이때 사용자를 강제로 오프라인 상태로 만들고 로그인 페이지로 돌아갈 수 있습니다.
위 내용은 사용자 원격 로그인 알림 기능을 구현하는 PHP 코드 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!