1、MVC与Struts映射
1.1控制器层:FilterDispatcher是核心控制器,它负责拦截和过滤所有的用户请求,遇到action结尾的请求就转入到Struts框架来处理。
action都被定义在struts.xml中,主要包含有name和class属性
?action实例不再与servlet api耦合了,因此无法直接处理用户请求
1.2显示层:jsp等视图,?需要在配置文件result子元素时指明type属性
提供了一套标记库
1.3模型层:后端业务逻辑处理,会被action调用处理用户请求
?控制器是通过工厂模式获得模型实例的
2、流程大致是这样的:
1.浏览器发送请求
2.核心控制器FileterDispatcher根据请求决定调用合适的Action[web.xml配置FilterDispatcher]
3.拦截器自动对应通用的功能
4.回调用Action上的execute方法
5.Action的execute()方法处理结果信息输出到游览器
注:【struts.xml】将action与结果页面关联在一起,对Action类进行配置
3.体系结构
4.Action专栏
1、要么继承ActionSupport类,要么实现Action接口,然后重载或覆写execute方法。注意ActionSupport是Action的实现类
Action接口的实现如下:
5.在Action中接收用户输入的几种方式
IOC方式:
具体方式有分为三种
(1)使用Action类的属性接收用户输入
类的属性要与jsp界面上的属性一一对应
(2)使用领域对象POJO接收[无属性了]
领域对象封装了属性,在类中使用POJO对象[private User user],在jsp界面上就使用类中的属性名[user].pojo类中的属性名[name或password],比如user.name
注意:POJO对象就是简单的Java对象,就是普通的JAVABean
(3)使用ModelDriven方式
首先要实现ModelDriven接口,实例化POJO对象,实现execute方法和getModel方法[此方法返回一个接收输入数据的模型对象[user]],在jsp界面上就使用模型对象中的属性名[name]
6.访问Servlet API对象[不易考]
struts用三个Map对象来替代HttpServletRequest、HttpSession和ServletContext,相当于封装,于是在Action里面,我们使用servlet对象对应的Map对象来保存和读取数据,要获得这三个对象,就要使用ActionContext类,类中有如下方法:
public Map getSession()//得到了封装了HttpSession的Map对象
piblic Map getApplication()
public Object get(Object key)//获取request对象
ActionContext context = ActionContext.getContext();//获取Action的上下文
context.getSession();//获取到了
第一种是非Ioc方式[解耦方式]
第二种是Ioc方式[ioc:控制反转,是个容器,在容器里只需要描述哪一个组建需要哪一项服务,然后将这些联系在一起即可]
备注:Map(key,value)
7.struts配置详解
struts-default包的作用:它是在struts-default.xml文件中定义的,这个包定义了struts2内置的结果类型(包括Servlet转发、Servlet的重定向、FreeMarker模板输出,XSTL渲染、内置拦截器和不同拦截器组成的拦截器栈等)
struts.xml作用:管理Action,配置action的拦截器,action和result的映射等,由框架自动加载。
1.relust的结果类型包括:
dispatcher转发[默认]、redirect重定向、redirectAction重定向[常用]、plainText
a、其中dispatcher有两个参数location和parse
实例场景,怎么带id号传参到jsp页面?
解决方案:可以在result设置location参数时,采用${id}(OGNL表达式)的语法从action中获取id属性的值。如下:
<param name="location">/view.jsp?id=${id}</param>
b、redirectAction有两个参数actionName和namespace
c、plainText结果类型有两个参数location和charSet
2.全局结果 写在Action前
<gboal-results>
<relust name="error">/error.jsp</result>
<gboal-results>
<action></action>
3、异常处理:通过拦截器对struts抛出异常进行捕获,这个拦截器是ExceptionMappingInterceptor
exception-mapping有两个参数分别是exception和result
<action>
<exception-mapping exception="cn.com.MyException" result="error"/>
//捕获到异常然后链接到/error.jsp
8.OGNL表达式可以调用任何方法
它可以存取对象的任意属性,调用对象的方法,遍历整个对象(有根对象)的结构图,实现字段类型转化等功能。它是使用相同的表达式去存取对象的属性。
[a、基础] :
实际是一个Map对象
默认调用根对象,在调用非根对象加上#
[b、语法 ]:表达式的基础单元成为导航链,链的组成部分如下:
属性名词、方法调用、数组元素
例如name.toCharArray()[0].numericValue.toString()
//获得OGNL Context的根对象的name对象
//调用toCharArray()方法,返回String类型
//获得该String对象的第一个字符
//获得该字符的numericValue属性,返回Integer对象
//把Integer对象转换为一个String类型值
[c、操作符 ]四个
,或. {} in/not in
[d、调用静态方法和调用字段 ]
@class@method(args)//调用静态方法
@class@field//访问静态字段(public权限)
9、验证
三种方法验证
(1)在Action的execute()方法进行验证
在资源文件中添加错误消息:将错误信息在国际化文件中进行配置
error.username.mess=${getText(“username”)}//不能为空error.password.mess=${getText(“password”)}//不能为空
if(username==null || username.equals(“”))
addFieldError(“username”, “error.username.mess”);
//addFieldError("字段名","错误信息")给一个字段(属性)添加错误消息
(2)使用ActionSupport validate()方法进行验证
validate()方法在execute()前面执行,如果验证不通过,自动转入到input试图(需要在strust.xml配置input)
(3)validateXxx()进行验证,此方法无返回值,防止execute代码急剧膨胀【建议用】
注意:doDefault()方法的验证方法是validateDefault()
execute()方法的验证方法是validateExecute()
10、实现国际化
a、实现两个类ResourceBundle抽象类:语言环境资源对象
和Local类提供本地信息
public Locale(String language,String country)[zh,CN]
b、参数化国际化字符串
11、类型转换
public Object convertValue(Map context,Object value,Class toType)
//参数context是表示OGNL上下文Map对象
//value是需要转换的对象
//toType是要转换的目标类型
12、拦截器
【自定义拦截器】:拦截器必须是无状态的,不要使用在API提供的ActionInvocation之外的任何东西。换句话 说,在拦截器类中不应该有实例变量。
有如下二种方式:
实现Interceptor接口
继承AbstractInterceptor类(一般会选择此种方式)
excludeMethods要排除的方法
includeMethods要拦截的方法
interceptor-ref元素指定引用的拦截器
interceptors元素中使用interceptor元素定义拦截器
< interceptor-stack name="stack">
< interceptor-ref name =“before” />
< interceptor-ref name =“after” />
< interceptor-stack>