struts2拦截器底层原理

1 拦截器底层使用两个原理

第一个 aop思想

(0)后面在spring里面把aop做更深层次分析

(1)文字描述:

Aop是面向切面(方面)编程,有基本功能,扩展功能,不通过修改源代码方式扩展功能

(2)画图分析:

第二个 责任链模式

(1)在java中有很多的设计模式,责任链模式是其中的一种

(2)责任链模式和过滤链很相似的

责任链模式:

 要执行多个操作,有添加、修改、删除三个操作。

首先执行添加操作,添加操作执行之后 做类似于放行操作,执行修改操作,修改操作执行之后做类似于放行操作,执行删除操作

过滤链:一个请求可有多个过滤器进行过滤,每个过滤器只有做放行才能到下一个过滤器

2 aop思想和责任链模式如何应用到拦截器里面?

(1)文字描述:

- 拦截器在action对象创建之后,action的方法执行之前执行

 

- 在action方法执行之前执行默认拦截器,执行过程使用aop思想,在action没有直接调用拦截器的方法,使用配置文件方式进行操作

 

- 在执行拦截器时候,执行很多的拦截器,这个过程使用责任链模式

-- 假如执行三个拦截器,执行拦截器1,执行拦截器1之后做放行操作,执行拦截器2,执行拦截器2之后做放行,执行拦截器3,执行拦截器3之后放行,执行action的方法

 

(2)画图分析

3 查看源代码

拦截器类的代码如下:

 1 public class LoginInterceptor extends MethodFilterInterceptor {
 2 
 3     @Override
 4     protected String doIntercept(ActionInvocation invocation) throws Exception {
 5         HttpServletRequest request = ServletActionContext.getRequest();
 6         Object obj = request.getSession().getAttribute("username");
 7         if(obj != null){
 8             return invocation.invoke();
 9         }else{
10             return "login";
11         }
12     }
13 }

同时,我们还需在xml文件中配置过滤器,下面代码写在package的里面,action的外面,配置拦截器类的路径,代码如下:

1 <interceptors>
2         <interceptor name="logininterceptor" class="cn.itcast.interceptor.LoginInterceptor"></interceptor>
3     </interceptors>

最后,还有一个问题,当我们配置了过滤器之后,action中的所有方法就都不能执行了,所以,我们应该配置不过滤的方法,此段方法写在action标签的里面:

1 <interceptor-ref name="logininterceptor">
2                 <param name="excludeMethods">login</param>
3             </interceptor-ref>
4             <interceptor-ref name="defaultStack"></interceptor-ref>

 

posted @ 2017-04-14 12:40  崔布斯  阅读(482)  评论(0编辑  收藏  举报