1

1.struts2的开发流程

  • 在web.xml文件中定义核心Filter拦截用户请求。

    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>

    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
  • 通过post或get提交请求。

  • 定义处理用户请求的Action类。
    在MVC框架中,控制器C实际上是由拦截所有用户请求,处理请求的通用代码两个部分共同组成的,实际的业务逻辑则由Action来处理。

MVC框架的底层机制:

核心Servlet或Filter接收到用户的请求后,通常会对用户请求进行简单处理,例如解析、封装参数等,然后通过反射来创建Action实例,并通过调用Action的制定方法来处理用户请求。

  • 配置Action。

  • 配置处理结果和物理视图的映射关系。

  • 编写视图资源。

2. struts2配置文件

struts2的默认配置文件为struts.xml,该文件应放在web应用的类加载路径下,通常在WEB-INF/classes路径下。struts.xml的最大作用是配置Action和请求之间的对应关系,并配置逻辑视图名和物理视图资源之间的相对关系,即返回结果和jsp文件的物理位置的关系。

struts2配置常量共有三种方式:

  1. 通过struts.properites文件

  2. 通过struts.xml配置文件(推荐在此文件定义struts属性)

  3. 通过Web应用的web.xml文件

通常struts2框架按以下搜索顺序进行加载。

  • struts-default.xml

  • struts-plugin.xml

  • struts.xml

  • struts.properties

  • web.xml

如果多个文件中配置了同一个struts常量,最后一个文件的配置会覆盖前面文件的配置。
为避免struts.xml的文件过大,可将配置文件分解成多个配置文件,然后在struts.xml文件中包含其他配置文件。

    <include file="struts-part1.xml"/>

3. 实现Action

为了使开发的Action更规范,Struts2提供了一个Action接口,定义了Struts2的Action处理应该实现的规范。

public interface Action {  
  
    //定义Action接口里包含的一些结果字符串  
    public static final String ERROR = "error";  
    public static final String INPUT = "input";  
    public static final String LOGIN = "login";  
    public static final String NONE = "none";  
    public static final String SUCCESS = "success";  
      
    //定义处理用户请求的execute()方法  
    public String execute() throws Exception;  
}  

上面的Action接口里只定义了一个execute()方法,该接口规范规定了Action类应该包含一个execute()方法,该方法返回一个字符串,此外,该接口还定义了5个字符串常量,他的作用是统一execute()方法的返回值。除此之外,struts2为Action接口提供了一个实现类:ActionSuport。该类提供了许多默认方法,比如默认的用户请求处理方法,数据校验方法等,一般Action类继承ActionSuport类。

4. 配置Action

struts2框架中的核心组件就是Action、拦截器等,struts2利用package和namespace来对多个Action和拦截器进行管理。

      <!-- package提供了将多个Action组织为一个模块的方式
        package的名字必须是唯一的 package可以扩展 当一个package扩展自
        另一个package时该package会在本身配置的基础上加入扩展的package
        的配置 父package必须在子package前配置 
        name:package名称
        extends:继承的父package名称
        abstract:设置package的属性为抽象的 抽象的package不能定义action 值true:false
        namespace:定义package命名空间 该命名空间影响到url的地址,例如此命名空间为/test那么访问是的地址为http://localhost:8080/struts2/test/XX.action
     -->
    <package name="com.kay.struts2" extends="struts-default" namespace="/test">
        <interceptors>
            <!-- 定义拦截器 
                name:拦截器名称
                class:拦截器类路径
             -->
            <interceptor name="timer" class="com.kay.timer"></interceptor>
            <interceptor name="logger" class="com.kay.logger"></interceptor>
            <!-- 定义拦截器栈 -->
            <interceptor-stack name="mystack">
                <interceptor-ref name="timer"></interceptor-ref>
                <interceptor-ref name="logger"></interceptor-ref>
            </interceptor-stack>
            
             <!-- 定义默认的拦截器 每个Action都会自动引用
         如果Action中引用了其它的拦截器 默认的拦截器将无效 -->
        <default-interceptor-ref name="mystack"></default-interceptor-ref>
        
        
        <!-- 全局results配置 -->
        <global-results>
            <result name="input">/error.jsp</result>
        </global-results>
        
        <!-- Action配置 一个Action可以被多次映射(只要action配置中的name不同)
             name:action名称
             class: 对应的类的路径
             method: 调用Action中的方法名
        -->
        <action name="hello" class="com.kay.struts2.Action.LoginAction">
            <!-- 引用拦截器
                name:拦截器名称或拦截器栈名称
             -->
            <interceptor-ref name="timer"></interceptor-ref>
        
            <!-- 节点配置
                name : result名称 和Action中返回的值相同
                type : result类型 不写则选用superpackage的type struts-default.xml中的默认为dispatcher
             -->
         <result name="success" type="dispatcher">/talk.jsp</result>
         <!-- 参数设置 
             name:对应Action中的get/set方法 
         -->
         <param name="url">http://www.sina.com</param>
        </action>
        </interceptors>
    </package>

流云
323 声望15 粉丝

« 上一篇
Java并发
下一篇 »
Java NIO总结