>  기사  >  백엔드 개발  >  javascript - 사용자가 일정 시간 동안 작업을 하지 않으면 시스템이 자동으로 종료되도록 PHP에서 구현하는 방법

javascript - 사용자가 일정 시간 동안 작업을 하지 않으면 시스템이 자동으로 종료되도록 PHP에서 구현하는 방법

WBOY
WBOY원래의
2016-08-08 09:06:371699검색

질문자는 thinkphp를 이용하여 개발했는데, 기존 기능으로는 (사용자의 조작 여부에 관계없이) 일정 시간 내에 세션을 종료하는 것이 가능하지만, 이 경우 경험이 확실히 나쁠 것입니다

사용자가 어떤 조작을 했는지 판단업계에서는일반적으로 어떤 상황을 말하는 건가요?
1. 마우스가 한동안 움직이지 않나요?
2. 마우스 클릭 동작이 없나요?
3...

js를 사용하여 이러한 작업을 쿠키에 기록하고 쿠키의 만료 시간을 설정할 수 있습니다. 그런데 쿠키가 만료된 경우 어떻게 해야 합니까?

답글 내용:

질문자는 thinkphp를 이용하여 개발했는데, 기존 기능으로는 (사용자의 조작 여부에 관계없이) 일정 시간 내에 세션을 종료하는 것이 가능하지만, 이 경우 경험이 확실히 나쁠 것입니다

사용자가 어떤 조작을 했는지 판단업계에서는일반적으로 어떤 상황을 말하는 건가요?
1. 마우스가 한동안 움직이지 않나요?
2. 마우스 클릭 동작이 없나요?
3...

js를 사용하여 이러한 작업을 쿠키에 기록하고 쿠키의 만료 시간을 설정할 수 있습니다. 그런데 쿠키가 만료된 경우 어떻게 해야 합니까?

옵션 1
서버측 구현 원칙: 사용자 테이블에 레코드 액세스 타임스탬프를 설정합니다. 사용자가 로그인이 필요한 페이지에 액세스할 때마다 현재 타임스탬프와 필요한 비활성 간격을 기록합니다. , 먼저 이 필드의 시간이 현재 시간보다 큰지 확인하고, 더 큰 경우 작업이 진행 중임을 의미하며 작업 없이 종료하는 데 필요한 시간에 타임스탬프를 추가하고 필드를 다시 업데이트합니다. . 또는 데이터베이스 레코드 대신 세션을 사용하십시오.
옵션 2
HTML5 저장소나 쿠키를 사용하는 프런트 엔드 구현 원칙은 저장 방식이 변경된 점만 제외하면 옵션 1의 아이디어와 동일합니다.
플랜 비교
플랜 1의 데이터베이스 저장 성능이 좋지 않습니다. HTML5는 하위 버전의 브라우저와 호환되지 않으며 쿠키를 비활성화하면 js가 유효하지 않습니다. 따라서 세션이 더 적합합니다.

사용자가 로그인한 후 15분 동안 아무런 조작이 없으면 자동으로 로그아웃하도록 해두었습니다. 마우스가 움직이고 있는지 여부에 초점을 맞추는 것이 아니라 마우스를 클릭했는지 또는 페이지를 새로 고쳤는지 여부에 따라 달라집니다. cookie 설정이 만료되면 cookie을 직접 삭제하면 됩니다. 참고용

일반적으로 작업이 있는지 여부는 액세스 요청이 있는지 여부를 의미하며, 요청이 있는 경우 백엔드는 쿠키를 새로 고치고 쿠키를 사용하여 만료를 제어할 수 있습니다.

물론 세션을 사용하여 요청 시간을 기록하고 새 요청 시 만료 여부를 확인하는 것이 더 안전합니다. 프런트 엔드가 강제 종료를 원하는 경우 하트비트 신호를 사용할 수 있습니다(물론 하트비트 신호는 요청 시간을 기록할 수 없습니다).

두 가지를 결합할 수도 있습니다. 즉, 사용 방법에 따라 여러 가지 방법이 있습니다.

세션 만료 시간은 php.ini에서 구성됩니다. 시간이 초과된 후 아무런 조치도 취하지 않으면 CLI가 自杀 자체적으로 작동합니다.

일반적으로 프런트 엔드는 이벤트가 트리거될 때마다 AJAX가 세션을 호출하여 사용자 세션이 중단 없이 유지될 수 있도록 하는 전역 이벤트 모니터입니다. 그렇지 않으면 동작하지 않고 php.ini에서 세션 만료 시간을 초과하면 해제됩니다.

장난하지 마세요. 여기 미리 준비된 것이 있습니다.

https://github.com/thorst/jqu...

유휴 상태로 진입하고 상태를 다시 활성화할 때 콜백이 있습니다. 유휴 상태로 진입할 때 서버에 xhr을 보내 세션을 종료하면 완료됩니다.

일반적으로 백그라운드 제어이며 세션 시간 초과를 설정합니다.

사용자의 작업 시간 제한은 SESSION의 수명 주기입니다. 세션 주기를 24분으로 가정하고 사용자가 12시에 로그인하고 12시 24분 이후에 아무 작업도 수행하지 않으면 SESSION은 이번에는 유효하지 않습니다. 이 작업을 수행하려면 다시 로그인해야 하며, 두 작업 간의 시간 차이는 24분을 초과할 수 없다는 제한이 있습니다. 추가: COOKIE가 유효하지 않은 경우 SESSION에 대한 로그인이 없어야 하며 사용자는 로그인되어 있지 않아야 합니다. PHP의 가비지 수집 메커니즘은 SESSION 파일이 redis에 저장된 경우 자동으로 정리하고 redis합니다. 또한 세션 데이터를 파괴하는 해당 방법이 있습니다.

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