>  기사  >  백엔드 개발  >  여러 사용자가 동시에 하나의 계정에 로그인하는 것을 방지하기 위해 PHP를 사용하는 방법은 무엇입니까?

여러 사용자가 동시에 하나의 계정에 로그인하는 것을 방지하기 위해 PHP를 사용하는 방법은 무엇입니까?

WBOY
WBOY원래의
2016-10-22 00:14:092268검색

수정 요구 사항: 계정에 로그인한 후 다른 사용자가 해당 계정에 다시 로그인할 수 있습니다! QQ 비정상 로그인처럼 현재 계정이 강제로 오프라인 상태가 됩니다. 구체적인 구현 아이디어를 주실 수 있나요? ?

답글 내용:

수정 요구 사항: 계정에 로그인한 후 다른 사용자가 해당 계정에 다시 로그인할 수 있습니다! 현재 계정은 QQ 비정상 로그인과 마찬가지로 강제로 오프라인 상태가 됩니다. 구체적인 구현 아이디어를 주실 수 있나요? ?

토큰을 생성하여 데이터베이스에 저장하고 세션에 씁니다. 작업 중 세션 토큰을 데이터베이스와 비교하여 다르면 로그아웃하세요.

"다른 사용자가 이 계정에 다시 로그인하면! 현재 계정은 강제로 오프라인됩니다."

여기서 시간 내에 또는 새로 고친 후(http 요청 다시 보내기)를 원합니다.
전자는 소켓이나 하트비트 패킷과 같은 긴 연결이 필요합니다.
@xfspace도 다음 작업이나 이후 작업에 대해 더 명확하게 만들었습니다.

로그인할 때마다 쿠키 확인을 위해 무작위 토큰이 생성됩니다.
로그인마다 다른 토큰이 생성되므로 이전에 생성된 쿠키는 당연히 무효화됩니다.
단, 사용자가 로그인할 경우 주의해야 합니다. 쿠키를 직접 복사하여 LAN상의 다른 컴퓨터의 브라우저에 삽입하여 사용하는 경우

그렇게 번거롭진 않아요.
1. 새 토큰 테이블을 만듭니다.
필드: token(토큰, 일반적으로 8개의 임의 문자열이면 충분함), uid(이 사이트의 사용자 ID),expiresIn(만료 시간)

사용자가 성공적으로 로그인하면 기록이 삽입되고 사용자의 이전 토큰 데이터가 모두 만료되거나 삭제됩니다. 이를 통해 동시에 하나의 유효한 토큰만 활성화되어 반복적인 로그인을 방지할 수 있습니다.

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