生活在开发者的领域, 就要日新月异的发展

 

struts2.0中xml配置文件

任何MVC框架都需要与Web应用整合,这就不得不借助于web.xml文件,只有配置在web.xml文件中Servlet才会被应用加载。
通常,所有的MVC框架都需要Web应用加载一个核心控制器,对于Struts2框架而言,需要加载FilterDispatcher,只要Web应用负责加载FilterDispatcher,FilterDispatcher将会加载Struts2框架。
因为Struts2将核心控制器设计成Filter,而不是一个普通Servlet。故为了让Web应用加载FilterDispatcher,只需要在web.xml文件中配置FilterDispatcher即可。
标准配置文件如下:

 

struts.xml

<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd" >
<struts>

    
<!-- include节点是struts2中组件化的方式 可以将每个功能模块独立到一个xml配置文件中 然后用include节点引用 -->
    
<include file="struts-default.xml"></include>
    
    
    
<!-- 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>
        
</interceptors>
        
        
<!-- 定义默认的拦截器 每个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>
    
</package>
</struts>

  1. <?xml version="1.0" encoding="UTF-8"?>   
  2. <web-app id="WebApp_9" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">   
  3.   
  4.     <display-name>Struts Blank</display-name>   
  5.   
  6.     <filter>   
  7.         <!-- 配置Struts2核心Filter的名字 -->   
  8.         <filter-name>struts2</filter-name>   
  9.         <!-- 配置Struts2核心Filter的实现类 -->   
  10.         <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>   
  11.           <init-param>   
  12.               <!-- 配置Struts2框架默认加载的Action包结构,可以没有。 -->   
  13.               <param-name>actionPackages</param-name>   
  14.               <param-value>org.apache.struts2.showcase.person</param-value>   
  15.           </init-param>   
  16.           <!-- 配置Struts2框架的配置提供者类 -->   
  17.           <init-param>   
  18.               <param-name>configProviders</param-name>   
  19.               <param-value>lee.MyConfigurationProvider</param-value>   
  20.           </init-param>   
  21.     </filter>   
  22.     <!-- 配置Filter拦截的URL -->   
  23.     <filter-mapping>   
  24.         <!-- 配置Struts2的核心FilterDispatcher拦截所有用户请求 -->   
  25.         <filter-name>struts2</filter-name>   
  26.         <url-pattern>/*</url-pattern>   
  27.     </filter-mapping>   
  28.   
  29.     <welcome-file-list>   
  30.         <welcome-file>index.html</welcome-file>   
  31.     </welcome-file-list>   
  32. </web-app> 

如上,当配置Struts2的FilterDispatcher类时,可以指定一系列的初始化参数,为该Filter配置初始化参数时,其中有3个初始化参数有特殊意义:
config:使用逗号隔开的字符串,每个字符串都是一个XML配置文件的位置。Struts框架将自动加载该属性指定的系列配置文件。
actionPackages:使用逗号隔开的字符串,每个字符串都是一个包空间,Struts2框架将扫描这些包空间下的Action。
configProviders:配置自己的ConfigurationProvider类。
还可以在此处配置Struts2常量,每个<init-param>元素配置一个Struts2常量,其中<param-name>子元素指定了常量name,而<param-value>子元素指定了常量value。
*在web.xml中配置了<Filter>元素,还需要配置该Filter拦截的URL。通常,我们让该Filter拦截所有的用户请求。可以能过<filter-mapping>元素配置。

posted on 2010-12-15 15:24  施大爷  阅读(470)  评论(0编辑  收藏  举报

导航