一、拦截器概述
1.1 在struts2框架中封装了很多功能,struts2里面封装的功能都是在拦截器里面,struts2里面又很多拦截器,但不是每次这些拦截器都执行,每次执行型默认的拦截器。
默认拦截器的位置如下: ------.>>>>
注:拦截器都是在action对象创建之后,方法执行之前进行执行的。
1.2拦截器的底层原理
拦截器底层使用了两个原理 第一个 AOP思想(简述): 就是面向切面编程,有基本功能,扩展功能,不通过修改源代码扩展功能。
aop的图解:
第二个 责任链模式:责任链模式是java众多设计模式中的一种,它和过滤链很相似。例如 要执行多个操作 有添加,修改,删除。首先执行添加操作,执行完毕后作出类似方形的操作后,执行修改操作,操作完成后作出类似放行的操作,最后执行删除操作。
过滤链:
二、拦截器的执行过程
2.1拦截器是在action对象创建之后 ,方法执行之前执行,在action执行之前执行默认拦截器,执行过程使用aop思想,在action中没有直接调用拦截器的方法,而是使用配置文件方式进行操作。在执行拦截器时,执行很多拦截器,这个过程中使用责任链模式,假如执行三个拦截器,执行拦截器1,执行拦截器1之后做放行操作,执行拦截器2,执行拦截器2之后做放行,执行拦截器3,执行拦截器3之后放行,执行action的方法。
如图:
2.2源码的分析查看
》执行action
》创建action对象,使用动态代理方式
》执行action的方法
》遍历执行众多拦截器
》类似放行的操作
注:
1 过滤器和拦截器区别
(1)过滤器:过滤器理论上可以任意内容,比如html、jsp、servlet、图片路径
(2)拦截器:拦截器只可以拦截action
2 Servlet和action区别
(1)servlet默认第一次访问时候创建,创建一次,单实例对象
(2)action每次访问时候创建,创建多次,多实例对象
三、自定义拦截器
3.1在struts2里面有很多的拦截器,这些拦截器是struts2封装的功能,但是在实际开发中,struts2里面的拦截器中可以没有要使用的功能,这个时候需要自己写拦截器实现功能,拦截器的结构,通过代码可以看到
继承类
接口里的三个方法初始化:
销毁:
逻辑操作:
3.2在开发中一般不建议这中方式,而是使用另外一种方式,写一个继承MethodFilterInterceptor类是心啊让action里面某个的方法不进行拦截。
3.3让拦截器和aciton产生关联 不是通过action'调用拦截器的方法,而是通过配置文件让其建立联系的
例如:自定义登陆拦截器
添加登录拦截器功能
(1)判断是否登录:判断session里面是否有名称是username的值
(2)拦截器实现过程
第一步 创建类,继承MethodFilterInterceptor类
第二步 重写MethodFilterInterceptor类里面的方法写拦截器逻辑
第三步 配置actin和拦截器之间的关联关系(注册拦截器)
(1)在要拦截的action标签所在的package标签里面声明拦截器
(2)在具体的action标签中使用已经声明的拦截器
(3)struts2里面执行很多的默认拦截器,但是如果在action里面配置自定义拦截器,
问题:默认的拦截器不会执行了
解决:把默认拦截器手动使用一次
(4)配置拦截器,对action里面所有的方法都进行拦截
(1)在action里面有login的登录的方法,这个方法不需要拦截,如果这个方法都拦截,问题是,永远登录不进去了
(2)解决:让login方法不进行拦截
- 直接通过配置方式让action里面某些方法不进行拦截
四、struts2中的标签问题
struts2的标签库
struts2标签使用在jsp页面中
s:property 和ognl表达式在jsp页面中获取值栈数据
s:iterator 获取值栈list集合数据 ,表示list集合
s:debug 查看值栈结构和数据
struts2中的表单标签
1 html表单标签
(1)form : action、method、enctype
(2)输入项
- 大部分在input里面封装 type=”值”
- text:普通输入项
- password:密码输入项
- radio:单选输入项
- checkbox:复选输入项
- file:文件上传项
- hidden:隐藏项
- button:普通按钮
- submit:提交按钮
- image:图片提交
- reset:重置
- select:下拉输入项
- textarea:文本域
2在struts2中对应的标签