struts2.0配置文件(转)

<!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>
    
  <!-- 该属性指定需要Struts2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts2处理。
  如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。 -->
  <constant name="struts.action.extension" value="do,php"/>

  <!--解决乱码 -->
  <constant name="struts.i18n.encoding" value="UTF-8"/>

  <!-- 设置浏览器是否缓存静态内容,默认值为true(生产环境下使用),开发阶段最好关闭 -->
  <constant name="struts.serve.static.browserCache" value="false"/>
<!-- 当struts的配置文件修改后,系统是否自动重新加载该文件,默认值为false(生产环境下使用),开发阶段最好打开 -->
  <constant name="struts.configuration.xml.reload" value="true"/>

  <!-- 开发模式下使用,这样可以打印出更详细的错误信息 -->
  <constant name="struts.devMode" value="true"/>

  <!-- 默认的视图主题 -->
  <constant name="struts.ui.theme" value="simple"/>

<!-- 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: 对应的类的路径,如果没有为action指定class,默认是ActionSupport method: 调用Action中的方法名,如果没有为action指定method,默认执行action中的execute()方法 --> <action name="hello" class="com.hanzhi.action.LoginAction"> <!-- 引用拦截器 name:拦截器名称或拦截器栈名称 --> <interceptor-ref name="timer"></interceptor-ref> <!-- 节点配置
         如果没有为action指定result,默认值为success. name : result名称 和Action中返回的值相同 type : result类型,不写则选用superpackage的type,struts-default.xml中的默认为dispatcher
              result类型包括:dispatcher(默认值,转发)、redirect(重定向)、redirectAction(重定向到别的命名空间下的action)
--> <result name="test1" type="dispatcher">/talk.jsp</result>
      <result name="test2" type="redirectAction">
        <param name="actionName">helloworld</param>
        <param name="nameSpace">/test</param>

      </result>
      
      <!--在result中还可以使用${属性名}表达式访问action中的属性,表达式里的属性名对应action中的属性名-->
      <result name="test3" type="redirect">/index.jsp?username=${username}</result>
<!-- 参数设置 name:对应Action中的get/set方法 --> <param name="url">http://www.sina.com</param> </action>

    <!--通配符
      *为通配符,{1}为*所替换的内容,如用户访问的是addUser.action,则*就被自动替换为add,{1}处也自动使用add替换。

    -->
    <action name="*User" class="com.hanzhi.action.ManagerUserAction" method="{1}">
        
<result name="success">/{1}User.jsp</result>
    </action>
</package> </struts>

 转载自:

(1)http://www.cnblogs.com/linjiqin/archive/2011/03/15/1985361.html

(2)http://www.cnblogs.com/kay/archive/2007/11/28/976120.html

posted @ 2013-03-07 11:26  登峰观月  阅读(178)  评论(0编辑  收藏  举报