Struts2学习笔记整理(十一)-----拦截器实现原理及源码分析
一、拦截器底层原理
1、AOP思想
(1)文字描述
Aop是面向切面(方面)编程,有基本功能,扩展功能,不通过修改源代码方式扩展功能。
(2)画图分析

2、责任链模式
(1)在java中有很多的设计模式,责任链模式是其中的一种
(2)责任链和过滤链很相似的
责任链模式:
要执行多个操作,有添加、修改、删除三个操作。
首先执行添加操作,添加操作执行之后做类似于放行操作,执行修改操作,修改操作执行之后做类似于放行操作,执行删除操作。
过滤链:一个请求可以有个过滤器进行过滤,每个过滤器只有做放行才能到下一个过滤器
3、aop思想和责任链模式如何应用到拦截器里面?
(1)文字描述:
-拦截器在action对象创建之后,action的方法执行之前执行
-在action方法执行之前执行默认拦截器,执行过程使用aop思想,在action没有直接调用拦截器方法,使用配置文件进行操作
-在执行拦截器时候,执行很多的拦截器,这个过程使用责任链模式
二、拦截器源码分析
(1)执行action
.class

(2)创建action对象,使用动态代理方法


(3)执行action


(4)执行很多的拦截器,遍历执行


类似于放行的操作的方法


三、拦截器和过滤器区别
(1)过滤器:过滤器理论上可以过滤任意内容,比如html、jsp、servlet、图片路径
(2)拦截器:拦截器只可以拦截action
四、servlet和action区别
(1)servlet默认第一次访问时候创建,创建一次,单实例对象
(2)action每次访问时候创建,创建多次,多实例对象
浙公网安备 33010602011771号