세션 만료 시간 설정 방법, 구체적인 방법은 다음과 같습니다.
1. Java 코드
request.getSession().setMaxInactiveInterval(1800);/*秒为单位,1800= 60*30 即30分种*/
2. web.xml
<session-config> <!--分钟为单位--> <session-timeout>30</session-timeout> </session-config>
3. 웹 서버 resin.conf, tomcat,
<session-config> <!--分钟为单位--> <session-timeout>30</session-timeout> <enable-url-rewriting>false</enable-url-rewriting> </session-config>
우선순위: 1 > 3 > 2
일반적으로 Tomcat을 다시 시작해도 세션이 무효화되지 않습니다
일반적으로 시스템의 경우 세션이 실패한 후에 일부 작업을 수행해야 할 수도 있습니다.
(1) 사용자 수를 제어합니다. 세션이 실패하면 시스템의 사용자 수가 1명씩 줄어듭니다. 등이 있으며, 사용자 수는 특정 범위 내에서 제어됩니다. 시스템 성능을 보장합니다.
(2) 세션이 유효한 경우 동일한 사용자가 로그인하면 해당 사용자가 로그인했다는 메시지가 표시됩니다. 세션이 만료되면 프롬프트 없이 바로 로그인할 수 있습니다.
그럼 세션이 만료된 후 일련의 작업을 수행하는 방법은 무엇입니까?
여기서 리스너를 사용해야 합니다. 즉, 여러 가지 이유로 세션이 실패하는 경우 리스너가 이를 듣고 리스너에 정의된 프로그램을 실행할 수 있습니다.
리스너 클래스는 다음과 같습니다. HttpSessionListener 클래스에는 sessionCreated 및 sessionDestroyed의 두 가지 메소드가 있습니다.
이 클래스를 상속하여 각각 구현할 수 있습니다.
sessionCreated는 세션이 생성될 때 실행되는 메소드를 의미합니다
sessionDestroyed는 세션이 실패할 때 실행되는 메소드를 의미합니다
는 다음과 같습니다. 🎜>
web.xml에서 다음 리스너를 선언하면 됩니다.public class OnlineListener implements HttpSessionListener{ public void sessionCreated(HttpSessionEvent event) { HttpSession ses = event.getSession(); String id=ses.getId()+ses.getCreationTime(); SummerConstant.UserMap.put(id, Boolean.TRUE); //添加用户 } public void sessionDestroyed(HttpSessionEvent event) { HttpSession ses = event.getSession(); String id=ses.getId()+ses.getCreationTime(); synchronized (this) { SummerConstant.USERNUM--; //用户数减一 SummerConstant.UserMap.remove(id); //从用户组中移除掉,用户组为一个map } } }
예를 들어 ServletContextListener와 HttpSessionListener 두 인터페이스를 동시에 구현하고 해당 메서드 등을 다시 작성해야 합니다.