1什么是值栈html
(1)action和servlet区别java
2 如何获取值栈对象程序员
3 值栈内部结构spring
(1)root和context数据库
4 向值栈放数据编程
(1)向值栈放字符串设计模式
(2)向值栈放对象session
(3)向值栈放list集合框架
5 从值栈获取数据ssh
(1)从值栈获取字符串
(2)从值栈获取对象
<s:property>
(3)从值栈获取list集合
<s:iterator>
6 EL表达式获取值栈数据
(1)加强request里面getAttribute方法
7 ognl表达式 #、%使用
1 拦截器概述
2 拦截器底层原理
3 过滤器和拦截器区别
4 自定义登陆拦截器
5 struts2标签库(会用)
6 struts2表单标签
1 struts2是框架,封装了不少的功能,struts2里面封装的功能都是在拦截器里面
2 struts2里面封装了不少的功能,有不少拦截器,不是每次这些拦截器都执行,每次执行默认的拦截器
3 struts2里面默认拦截器位置
4 拦截器在何时执行?
(1)在action对象建立以后,action的方法执行以前
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)执行action
(2)建立action对象,使用动态代理方式
(3)执行action的方法
(4)执行不少的拦截器,遍历执行
相似于放行的操做的方法
1 过滤器和拦截器区别
(1)过滤器:过滤器理论上能够任意内容,好比html、jsp、servlet、图片路径
(2)拦截器:拦截器只能够拦截action
2 Servlet和action区别
(1)servlet默认第一次访问时候建立,建立一次,单实例对象
(2)action每次访问时候建立,建立屡次,多实例对象
1 在struts2里面有不少的拦截器,这些拦截器是struts2封装的功能,可是在实际开发中,struts2里面的拦截器中能够没有要使用的功能,这个时候须要本身写拦截器实现功能
2 拦截器结构
(1)查看源代码看拦截器结构
- 继承类
在接口里面有三个方法
: 初始化操做
:销毁
:拦截逻辑的操做
(2)开发中,建议使用另一种方式
- 写类,继承 MethodFilterInterceptor类实现
-- 让action里面某个的方法不进行拦截
(3)让拦截器和action有关系
- 不是在action调用拦截器的方法,而是经过配置文件方式让创建关系
1 需求:在项目中,有不少的action的超连接,实现只有是登陆的状态,才能够点击action的超连接实现功能,若是不是登陆状态,点击action超连接返回到登陆页面
2 登陆的状态:使用session域对象实现
(1)登陆成功以后,把数据放到session里面
(2)判断session是否有值,能够知道是不是登陆状态
3 实现登陆的基本功能
(1)查询数据库判断用户名和密码(做业)
4 添加登陆拦截器功能
(1)判断是否登陆:判断session里面是否有名称是username的值
(2)拦截器实现过程
第一步 建立类,继承MethodFilterInterceptor类
第二步 重写MethodFilterInterceptor类里面的方法写拦截器逻辑
第三步 配置action和拦截器关系(注册拦截器)
(1)在要拦截的action标签所在的package标签里面声明拦截器
(2)在具体的action标签里面使用声明的拦截器
(3)struts2里面执行不少的默认拦截器,可是若是在action里面配置自定义拦截器,
问题:默认的拦截器不会执行了
解决:把默认拦截器手动使用一次
5配置拦截器,对action里面全部的方法都进行拦截
(1)在action里面有login的登陆的方法,这个方法不须要拦截,若是这个方法都拦截,问题是,永远登陆不进去了
(2)解决:让login方法不进行拦截
- 直接经过配置方式让action里面某些方法不进行拦截
6 若是登陆状态,直接到功能页面,若是不是登陆显示登录页面
登陆以后出现小问题:
(1)设置打开位置,在form标签里面
0 struts2标签使用jsp页面中
1 s:property: 和ognl表达式在jsp页面中获取值栈数据
2 s:iterator: 获取值栈list集合数据,表示list集合
3 s:debug: 查看值栈结构和数据
1 html表单标签
(1)form : action、method、enctype
(2)输入项
- 大部分在input里面封装 type=”值”
- text:普通输入项
- password:密码输入项
- radio:单选输入项
- checkbox:复选输入项
- file:文件上传项
- hidden:隐藏项
- button:普通按钮
- submit:提交按钮
- image:图片提交
- reset:重置
- select:下拉输入项
- textarea:文本域
2 在struts2里面对应html表单标签大部分都有
放到ssh练习中讲到
1 struts2文件上传
2 错误处理机制 input
1 Action
(1)action建立(继承ActionSupport类)
(2)配置访问action的方法(通配符)
(3)action获取表单数据
- 模型驱动
(4)action操做域对象
(5)result标签里面type属性
2 值栈
(1)值栈结构
(2)向值栈放数据
(3)从值栈获取数据
3 拦截器
(1)拦截器原理
(2)自定义拦截器
- 继承类
- 写拦截器逻辑
- 配置拦截器
-- 配置让action某些方法不进行拦截
参考资料:
《黑马程序员》