추천 무료 학습: Basic Java Tutorial
일반 시스템에 로그인한 후 현재 세션 만료 시간이 설정되어 사용자가 오랫동안 서버와 상호 작용하지 않으면 사용자는 자동으로 로그아웃되고 세션이 삭제됩니다.
세 가지 구체적인 설정 방법이 있습니다.
1. 웹 컨테이너에서 설정(예: tomcat)
tomcat-7.0confweb.xml에서 설정 다음은 기본 구성입니다. tomcat7.0:
<session-config> <session-timeout>30</session-timeout> </session-config>
Tomcat의 기본 세션 시간 제한은 30분이며 필요에 따라 수정할 수 있습니다. 음수 또는 0은 세션 만료 시간에 제한이 없음을 의미합니다.
여기서 시간 설정에 유의해야 합니다. 이 세션의 경우 클라이언트가 아닌 서버를 기준으로 계산됩니다. 따라서 프로그램을 디버깅하는 경우 클라이언트가 아닌 서버측 시간을 수정해야 합니다.
<!--时间单位为分钟--> <session-config> <session-timeout>15</session-timeout> </session-config>
세 가지 우선순위 수준: 1 < 2 < 일반적인 시스템에서는 세션이 실패한 후 몇 가지 작업을 수행해야 할 수도 있습니다:
1. 사용자 수를 제어합니다. 세션이 실패하면 시스템의 사용자 수를 줄이고 특정 범위 내에서 사용자 수를 제어합니다. , 시스템 성능 보장2. 사용자가 여러 번 로그인하도록 제어합니다. 세션이 유효한 경우 동일한 사용자가 로그인하면 사용자가 로그인했다는 메시지가 표시됩니다. 세션이 만료되면 메시지가 다를 수 있습니다. , 직접 로그인
그러면 세션이 만료된 후 일련의 작업을 수행하는 방법은 무엇입니까?여기에서는 리스너를 사용해야 합니다. 즉, 여러 가지 이유로 세션이 실패하면 리스너는 리스너에 정의된 프로그램을 수신하고 실행할 수 있습니다.
리스너 클래스는 sessionCreated 및 sessionDestroyed가 있는 HttpSessionListener 클래스입니다. 이 클래스를 상속하고 별도로 구현할 수 있습니다.sessionCreated는 세션이 생성될 때 실행되는 메서드를 참조합니다.
sessionDestroyed는 세션이 실패할 때 실행되는 메서드를 참조합니다. 예:
session.setMaxInactiveInterval(30*60);//以秒为单位,即在没有活动30分钟后,session将失效
public class OnlineUserListener implements HttpSessionListener{ public void sessionCreated(HttpSessionEvent event){ HttpSession session=event.getSession; String id=session.getId()+session.getCreationTime(); SummerConstant.UserMap.put(id,Boolean.TRUE);//添加用户 } public void sessionDestroyed(HttpSessionEvent event){ HttpSession session=event.getSession; String id=session.getId()+session.getCreationTime(); synchronized(this){ SummerConstant.USERNum--;//用户数减- SummerConstant.UserMap.remove(id);//从用户组中移除掉,用户组为一个map } } }
위 내용은 Java가 세션 시간 초과(만료)를 설정하는 시간에 대해 자세히 논의합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!