1.开发Interceptor类
用户自定义的拦截器一般需要继承AbstractInterceptor类,重写intercept方法
public class UserInterceptor extends AbstractInterceptor{ @Override public String intercept(ActionInvocation actionInvocation) throws Exception { //拿到当前执行的方法名,如果当前方法名不是login,就进行验证 //获取actioncontext对象 ActionContext actionContext = actionInvocation.getInvocationContext(); //获取action的代理对象 ActionProxy proxy = actionInvocation.getProxy(); String methodName = proxy.getMethod(); if(!"login".equals(methodName)) { //先获取当前登录的用户 Object userInfo = actionContext.getSession().get("userInfo"); if(userInfo == null) return "input"; else return actionInvocation.invoke(); }else{ //说明当前用户正在登录 return actionInvocation.invoke(); } } }
2.配置拦截器
配置拦截器栈
<interceptors> <interceptor name="userInterceptor" class="com.juaner.login.UserInterceptor"></interceptor> <interceptor-stack name="myStack"> <interceptor-ref name="defaultStack"/> <interceptor-ref name="userInterceptor"/> </interceptor-stack> </interceptors>
执行拦截器
<default-interceptor-ref name="myStack"></default-interceptor-ref>
3.拦截器的生命周期
- 服务器启动时,执行所有拦截器的创建,调用拦截器的init()方法;
- 用户访问时,首先创建Action实例;
- 然后执行拦截器的intercept()方法,该方法只有一个参数:ActionInvocation的对象actionInvocation。在该方法中调用actionInvocation.invoke()方法执行下一个拦截器;(类似于过滤器中的filterChain.doFilter()方法);
- invoke()方法链最后会执行Action的execute()方法;
- 最后执行拦截器intercept()方法中invoke()后的语句;