>  기사  >  백엔드 개발  >  현재 사용자가 다른 곳에 로그인했는지 확인하는 PHP 방법_php 팁

현재 사용자가 다른 곳에 로그인했는지 확인하는 PHP 방법_php 팁

WBOY
WBOY원래의
2016-05-16 20:26:251025검색

이 기사의 예에서는 PHP가 현재 사용자가 다른 곳에 로그인했는지 확인하는 방법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 구체적인 분석은 다음과 같습니다.

주요 아이디어는 다음과 같습니다.
1. 로그인 시 사용자의 SessionID를 기록해 주세요
2. 로그인 확인 시, 기록된 사용자의 SessionID와 현재 SessionID를 일치시키세요
3. 동일하지 않을 경우 다른 곳에서 로그인해주세요

전체 예제 코드를 보려면 여기를 클릭하세요이 사이트에서 다운로드하세요.

먼저 http://localhost/login_single/index.php에 접속해 로그인 상태를 확인해 보세요.
index.php 페이지 코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

//세션 열기
session_start();

header("콘텐츠 유형: 텍스트/html; charset=utf-8");

//세션에서 사용자 정보 가져오기
$username=$_SESSION['사용자 이름'];

//유효한지 판단하세요
if(!isset($username)){
echo "로그인되지 않았습니다!로그인";
종료();
}

//로그인 시 저장된 사용자의 SessionID
$sessin_id=file_get_contents('session_id/'.$username);

//현재 SessionID가 이전에 기록된 SessionID와 일치하지 않는 경우
//다른 곳에서 로그인했음을 나타냅니다.
if(session_id() != $sessin_id){
//현재 사용자 로그아웃
unset($_SESSION['사용자 이름']);
echo "다른 곳에서 로그인하셨습니다!다시 로그인하세요";
종료();
}그밖에{
echo "환영합니다:".$username;
echo " 로그아웃";
}

echo "

--로그인해야만 볼 수 있는 내용입니다--

";

로그인하지 않은 사용자의 경우 http://localhost/login_single/login.html 로그인 페이지로 이동하라는 메시지가 표시됩니다. login.html 페이지 코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.





로그인



사용자 이름:

비밀번호:




팁: 테스트 사용자 이름: admin 비밀번호: 123


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