重点:拦截器,action
Action是多例的,每次请求都会对应一个Action的实例(servlet容器中的servlet是单例的,线程安全问题)
如果业务逻辑很杂很多,怎么样考虑代码的耦合性?
拦截器:负责外围逻辑;
action:负责核心逻辑 。
对比servlet和Struts2
struts2的优点:老牌框架,应用多,结构性好,拦截器思想。
1、在web.xml中只需要配置一个过滤器就可以了;servlet配置复杂,不利于分组开发。
2、在配置文件中可以通过include标签把其他的struts2配置文件包含在struts.xml中。
3、在配置文件中有了包的概念(extends),继承包的功能
4、对response做了一些封装,形成结果集
dispatcher
redirect
redirectAction
缺点:采用值栈、OGNL、struts2标签库,降低了性能。
页面数据提交:
属性驱动拦截器,Action中的属性要有set方法,属性名和name一致
模型驱动拦截器,如果属性过多,用模型驱动,在action中创建一个接受请求参数的实例,并且要实现ModelDrivern接口的getModel方法,并返回这个实例。
好处:保证action与servlet容器松耦合,其实通过一系列措施实现了松耦合。
页面表现层使用ognl表达式,访问map栈加#号,对象栈直接访问属性即可。
提供了存储数据的数据结构,值栈(对象栈和map栈)
* 对象栈
* 当前请求的action默认在对象栈的栈顶
* 可以利用valueStack.getRoot().add方法把一个对象放入到对象栈中 push方法(放在栈顶)
* pop方法移除栈顶元素
* peek方法获取栈顶元素
* 利用valueStack.set方法把一个对象变成map存入到对象栈中
* 处于对象栈的属性可以不加#号直接访问
* 如果一个属性在对象栈中,在页面上利用struts2标签访问该属性
public class OgnlAction{
private String comment = "aa";
//set,get
}
在页面中使用标签:<s:textfiled name="comment"/>
这样文本框就能直接回显comment属性的值
* 当对象栈中出现相同的属性,从栈顶开始查找
* 利用valueStack的setValue方法可以改变对象栈中的属性的值
* map栈
* 可以利用ActionContext.getContext().put()把一个数据直接放入到map栈中
* request,session,application,parameters,attr都在map栈中,并且struts2对其进行了封装
* 可以把一个数据存放在上述的scope中
当前请求的action的方法别用get开头,会有安全性的隐患
请求采用url映射,可以使用通配符
对于struts2来说,整个处理流程是死的,拦截器和结果集是可插拔的。