Struts2笔记11 拦截器底层原理
1 拦截器底层使用两个原理
第一个 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>