>  기사  >  백엔드 개발  >  PHP 사용자 원격 로그인 알림 구현 코드

PHP 사용자 원격 로그인 알림 구현 코드

php中世界最好的语言
php中世界最好的语言원래의
2018-05-18 10:59:421643검색

이번에는 PHP 사용자를 위한 원격 로그인 알림 구현 코드를 가져오겠습니다. PHP 사용자를 위한 원격 로그인 알림 구현 시 주의사항은 무엇인가요?

보안 요구 사항, 특히 백엔드 관리가 상대적으로 높은 웹 사이트의 경우 계정이 도난당했는지 또는 현재 다른 사람이 로그인하여 백엔드 작업을 수행하고 있는지 확인해야 하는 경우가 있습니다. 이는 매우 안전하지 않습니다. 동시에 로그인하고 작업하는 개인은 계정을 강제로 오프라인 상태로 만들 수 있습니다.

물론 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'));
}

(3) 원격 로그인 문제 해결

백그라운드 작업의 경우 검증 및 작업 보안을 용이하게 하기 위해 기본적으로 기본 컨트롤러 BaseController가 먼저 생성되고 백그라운드의 다른 작업 컨트롤러가 이 기본 컨트롤러를 상속합니다. 백그라운드 작업의 각 단계 전에 사용자 상태 감지는 BaseController 컨트롤러의 초기화 _initialize() 메서드에 배치됩니다.

이제 _initialize() 메소드에서는 사용자 로그인 상태가 잠겨 있는지 등을 확인하는 것 외에도 로컬 session_id를 꺼내어 사용자 테이블에 저장된 session_id와 비교해야 합니다. 일치하지 않으면 해당 테이블 이름을 가진 계정이 다른 위치에 로그인됩니다. 이때 사용자를 강제로 오프라인 상태로 만들고 로그인 페이지로 돌아갈 수 있습니다.

rrreee물론, 원격 로그인을 위한 IP를 얻고 알림을 보낼 수도 있습니다:

🎜🎜이 기사의 사례를 읽은 후 방법을 마스터했다고 믿습니다. 더 흥미로운 정보를 보려면 다른 항목에 주의하세요. PHP 중국어 웹사이트에 관련 기사가 있습니다! 🎜🎜추천 자료: 🎜🎜🎜PHP 콜백 함수 및 익명 함수 사용 사례 분석🎜🎜🎜🎜🎜PHP 네임스페이스 네임스페이스 정의 및 가져오기 사용 사례 분석🎜🎜🎜

위 내용은 PHP 사용자 원격 로그인 알림 구현 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.