※ krfreedevlife 님의 글을 기반으로 HOOK 방식으로 재구성하였습니다.
https://hoai.tistory.com/entry/%EA%B7%B8%EB%88%84%EB%B3%B4%EB%93%9C-%EC%A4%91%EB%B3%B5%EB%A1%9C%EA%B7%B8%EC%9D%B8-%EB%B0%A9%EC%A7%80
동일한 계정으로 다른 브라우저나 기기에서 로그인 시,
이전 로그인 세션은 페이지 이동하는 순간 자동 로그아웃됩니다.
아직 충분히 검증된 방식은 아니므로, 사용 중 문제가 발생할 수 있습니다.
관련 의견이나 문제는 댓글로 공유해주시면 개선에 참고하겠습니다.
* /extend/z_duplicate_login_prevent.php
(extend 폴더에 z_duplicate_login_prevent.php 파일 생성)
(파일명은 변경 가능하나 alert() 사용을 위해 z_ 접두어는 붙이는 것을 권장)
[code]
<?php
if (!defined('_GNUBOARD_')) exit;
// 중복 로그인 방지 Hook
// 1. 로그인 성공 후 랜덤값 저장
add_event('member_login_check', 'prevent_duplicate_login', 10, 3);
function prevent_duplicate_login($mb, $link, $is_social_login) {
global $g5;
if ($mb['mb_id']) {
// 중복로그인 방지 검사값 생성 및 저장
$dbl_login = rand(10000, 99999);
sql_query("UPDATE {$g5['member_table']}
SET mb_1 = '{$dbl_login}'
WHERE mb_id = '{$mb['mb_id']}'");
set_session('ss_mb_1_ss', $dbl_login);
}
}
// 2. 매 페이지 로드 시 중복 로그인 체크
add_event('common_header', 'check_duplicate_login', 3, 0);
function check_duplicate_login() {
global $member;
// 로그인된 회원만 체크
if ($member['mb_id']) {
$ss_mb_1 = get_session('ss_mb_1_ss');
// 세션값과 DB값이 다르면 중복 로그인으로 판단
if ($ss_mb_1 != $member['mb_1']) {
// 소셜 로그인 로그아웃 처리
if (function_exists('social_provider_logout')) {
social_provider_logout();
}
// 세션 완전 제거
session_unset();
session_destroy();
// 중복 접속 알림 후 메인으로 이동
alert('중복접속으로 인하여 로그아웃 되었습니다.', G5_URL);
}
}
}
[/code]
댓글 10개
게시글 목록
| 번호 | 제목 |
|---|---|
| 24318 | |
| 24317 | |
| 24315 | |
| 24309 | |
| 24294 | |
| 24293 | |
| 24277 | |
| 24262 | |
| 24260 | |
| 24253 | |
| 24251 | |
| 24236 | |
| 24233 | |
| 24228 | |
| 24226 | |
| 24221 | |
| 24214 | |
| 24203 | |
| 24201 | |
| 24199 | |
| 24196 | |
| 24195 | |
| 24194 | |
| 24192 | |
| 24191 | |
| 24187 | |
| 24185 | |
| 24183 | |
| 24172 | |
| 24168 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기