Каков наилучший подход для обработки тайм-аутов сессии в Struts2?
У меня есть приложение struts2, и мне нужно обработать тайм-аут сеанса в зарегистрированном разделе.
Я имею в виду использование класса Interceptor:
public class SessionInterceptor extends AbstractInterceptor {
@Override
public String intercept(ActionInvocation invocation) throws Exception {
Map<String,Object> session = invocation.getInvocationContext().getSession();
if(session.isEmpty())
return "session";
return invocation.invoke();
}
}
В моем Struts.xml:
<struts>
<interceptor name="session" class="org.app.struts.interceptor.SessionInterceptor" />
<interceptor name="admin" class="org.app.struts.interceptor.AdminInterceptor" />
<interceptor-stack name="adminStack">
<interceptor-ref name="defaultStack"/>
<interceptor-ref name="session"/>
<interceptor-ref name="admin"/>
</interceptor-stack>
<action name="doaction" class="org.app.class" method="doAction">
<interceptor-ref name="adminStack" />
<result name="success">page.jsp</result>
<result name="error">error.jsp</result>
<result name="session">sessionexpired.jsp</result>
</action>
</struts>
Есть ли лучший подход?
Спасибо!
2 ответа
Попробуйте это: http://nickcoblentz.blogspot.com/2008/11/page-level-access-controls-in-struts-2.html и в web.xml:
<session-config>
<session-timeout>
30
</session-timeout>
</session-config>
это на 30 минут