`
Sev7en_jun
  • 浏览: 1225434 次
  • 性别: Icon_minigender_1
  • 来自: 广州
博客专栏
84184fc0-d0b6-3f7f-a3f0-4202acb3caf5
Apache CXF使用s...
浏览量:111305
社区版块
存档分类
最新评论

struts-config.xml中各个标签的说明

阅读更多

struts-config.xml中各个标签的说明
 
 原文:http://blogold.chinaunix.net/u3/100458/showart_2463630.html
 
关键字: struts-config.xml中各个标签的说明
前段时间在网上看见这个关于struts1的配置文件的文章,认为该文章比较详细,对我们配置该文件很有帮助,特此转载。向文章的原创者致礼!

<!-- struts-config.xml常用配置详解 2008年12月03日 -->

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 1.1//EN"
"http://jakarta.apache.org/struts/dtds/struts-config.dtd">

<!-- struts-config.xml中的元素必须按照上述doc指令中的dtd文档定义顺序书写,本例即遵从了dtd定义顺序 -->
<!-- struts-config是整个xml的根元素,其他元素必须被包含其内 -->

<struts-config><!-- struts-config 开始 -->
<!-- 1 ------------------------------------------------------------------------------------ -->
<!--
   名称:data-sources
   描述:data-sources元素定义了web App所需要使用的数据源
   数量:最多一个
   子元素:data-source
-->
<data-sources>
   <!--
名称:data-source
描述:data-source元素定义了具体的数据源
数量:任意多个
属性:
@key:当需要配置多个数据源时,相当于数据源的名称,用来数据源彼此间进行区别
@type:可以使用的数据源实现的类,一般来自如下四个库
  Poolman,开放源代码软件
  Expresso,Jcorporate
  JDBC Pool,开放源代码软件
  DBCP,Jakarta
   -->
   <data-source key="firstOne" type="org.apache.commons.dbcp.BasicDataSource">
<!--
名称:set-property
描述:用来设定数据源的属性
属性:
  @autoCommit:是否自动提交 可选值:true/false
  @description:数据源描述
  @driverClass:数据源使用的类
  @maxCount:最大数据源连接数
  @minCount:最小数据源连接数
  @user:数据库用户
  @password:数据库密码
  @url:数据库url
  @loginTimeout:超时
-->
<set-property property="url" value="jdbc:mysql://localhost:3306/数据库名称"/>
<set-property property="driverClass" value="com.mysql.jdbc.Driver"/>
<set-property property="autoCommit" value="true"/>
<set-property property="description" value=""/>
<set-property property="maxCount" value="10"/>
<set-property property="minCount" value="2"/>
<set-property property="user" value="root"/>
<set-property property="password" value=""/>
<!-- 或 -->
<set-property property="driverClass" value="org.gjt.mm.mysql.Driver" />
<set-property property="url" value="jdbc:mysql://localhost:3306/数据库名称" />
<set-property property="autoCommit" value="false" />
<set-property property="user" value="root" />
<set-property property="password" value="root" />
<set-property property="minCount" value="5" />
<set-property property="maxCount" value="10" />     
<set-property property="description" value="" />     
<set-property property="readOnly" value="false" />
<set-property property="loginTimeout" value="" />
   </data-source>
</data-sources>

<!-- 2 ------------------------------------------------------------------------------------ -->
<!--
   名称:form-beans
   描述:用来配置多个ActionForm Bean
   数量:最多一个
   子元素:form-bean
-->
<!-- Form-beans 定义 ActionForm -->
<form-beans><!-- form-beans 开始 -->
   <!--
名称:form-bean
描述:用来配置ActionForm Bean
数量:任意多个
子元素:form-property
属性:
@className:指定与form-bean元素相对应的配置类,一般默认使用org.apaceh.struts.config.FormBeanConfig,如果自定义,则必须继承 FormBeanConfig
@name:必备属性!为当前form-bean制定一个全局唯一的标识符,使得在整个Struts框架内,可以通过该标识符来引用这个ActionForm Bean。
@type:必备属性!指明实现当前ActionForm Bean的完整类名。
   -->
   <form-bean name="Hello" type="myPack.Hello">
<!--
名称:form-property
描述:用来设定ActionForm Bean的属性
数量:根据实际需求而定,例如,ActionForm Bean对应的一个登陆Form中有两个文本框,name和password,ActionForm Bean中也有这两个字段,则此处编写两个form-property来设定属性
属性:
  @className:指定与form-property相对应的配置类,默认是org.apache.struts.config.FormPropertyConfig,如果自定义,则必须继承FormPropertyConfig类
  @name:所要设定的ActionForm Bean的属性名称
  @type:所要设定的ActionForm Bean的属性值的类
  @initial:当前属性的初值
-->
<form-property name="name" type="java.lang.String"/>
<form-property name="number" type="java.lang.Iteger" initial="18"/>
</form-bean>

<!-- //////////////////////////////////////////////////////////////////////////////
<!-- 登录的 ActionForm
     <form-bean name="登录loginForm" type="org.apache.struts.validator.DynaValidatorForm">
          <form-property name="比如工作ID" type="java.lang.String"/>
  <form-property name="比如用户ID" type="java.lang.String"/>
       ... 等等
     </form-bean>
     <!-- 其他对应的 ActionForm
     <form-bean name="处理问题的Form" type="org.apache.struts.validator.DynaValidatorForm"/>
          <form-property name="标题,表字段" type="java.lang.String"/>
  <form-property name="姓名,表字段" type="java.lang.String"/>
       ... 等等
</form-bean>
/////////////////////////////////////////////////////////////////////////////////-->

<!-- ActionForm -- 对应 -->
<!--
@name:必备属性.为当前form-bean制定一个全局唯一的标识符,使得在整个Struts框架内,可以通过该标识符来引用这个ActionForm Bean - "userForm"
@type:必备属性.当前ActionForm Bean的完整类名 - "org.我的项目.struts.form.UserForm.java"
-->
        <form-bean name="userForm" type="org.我的项目.struts.form.UserForm" />
<form-bean name="adminForm" type="org.我的项目.struts.form.AdminForm" />

</form-beans><!-- form-beans 结束 -->

<!-- 3 ------------------------------------------------------------------------------------ -->
<!--
   名称:global-exceptions
   描述:处理异常
   数量:最多一个
   子元素:exception
-->
<global-exceptions>
   <!--
名称:exception
描述:具体定义一个异常及其处理
数量:任意多个
属性:
@className:指定对应exception的配置类,默认为org.apache.struts.config.ExceptionConfig
@handler:指定异常处理类,默认为org.apache.struts.action.ExceptionHandler
@key:指定在Resource Bundle种描述该异常的消息key
@path:指定当发生异常时,进行转发的路径
@scope:指定ActionMessage实例存放的范围,默认为request,另外一个可选值是session
@type:必须要有!指定所需要处理异常类的名字。
@bundle:指定资源绑定
   -->
   <exception
key=""hello.error
path="/error.jsp"
scope="session"
type="hello.HandleError"/>
</global-exceptions>

<!--
   名称:global-forwards
   描述:定义全局转发
   数量:最多一个
   子元素:forward
-->
<global-forwards>
   <!--
名称:forward
描述:定义一个具体的转发
数量:任意多个
属性:
@className:指定和forward元素对应的配置类,默认为org.apache.struts.action.ActionForward
@contextRelative:如果为true,则指明使用当前上下文,路径以“/”开头,默认为false
@name:必须配有!指明转发路径的唯一标识符
@path:必须配有!指明转发或者重定向的URI。必须以"/"开头。具体配置要与contextRelative相应。
@redirect:为true时,执行重定向操作,否则执行请求转发。默认为false
   -->
   <forward name="A" path="/a.jsp"/>
   <forward name="B" path="/hello/b.do"/>
</global-forwards>

<!-- 4 ------------------------------------------------------------------------------------ -->

<!--
   名称:action-mappings
   描述:定义action集合
   数量:最多一个
   子元素:action
-->
<action-mappings><!-- action-mappings 开始 -->
   <!--
名称:action
描述:定义了从特定的请求路径到相应的Action类的映射
数量:任意多个
子元素:exception,forward(二者均为局部量)
属性:
@attribute:制定与当前Action相关联的ActionForm Bean在request和session范围内的名称(key)
@className:与Action元素对应的配置类。默认为org.apache.struts.action.ActionMapping
@forward:指名转发的URL路径
@include:指名包含的URL路径
@input:指名包含输入表单的URL路径,表单验证失败时,请求会被转发到该URL中
@name:指定和当前Acion关联的ActionForm Bean的名字。该名称必须在form-bean元素中定义过。
@path:指定访问Action的路径,以"/"开头,没有扩展名
@parameter:为当前的Action配置参数,可以在Action的execute()方法中,通过调用ActionMapping的getParameter()方法来获取参数
@roles:指定允许调用该Aciton的安全角色。多个角色之间用逗号分割。处理请求时,RequestProcessor会根据该配置项来决定用户是否有调用该Action的权限
@scope:指定ActionForm Bean的存在范围,可选值为request和session。默认为session
@type:指定Action类的完整类名
@unknown:值为true时,表示可以处理用户发出的所有无效的Action URL。默认为false
@validate:指定是否要先调用ActionForm Bean的validate()方法。默认为true
注意:如上属性中,forward/include/type三者相斥,即三者在同一Action配置中只能存在一个。
   -->
   <action path="/search"
   type="addressbook.actions.SearchAction"
   name="searchForm"
   scope="request"
   validate="true"
   input="/search.jsp">
<forward name="success" path="/display.jsp"/>
   </action>

   <!-- ////////////////////////////////////////////////////////////////////////////////////////////////////
<!-- 配置进入主页的请求的 Action --
<action path="/index" scope="request" validate="false" input="error" type="com.项目.action.LogoutAction">
      <forward path="index" name="Index"/>
         </action>

         <!-- 配置员工或用户登录的Action --
<action path="/登录路径" name="登录loginForm" scope="request" validate="false" input="index" type="com.项目.action.登录loginAction">
      <forward path="要转发的页面比如/techSupport.do?method=goTechSupportView" name="GoTechSupportView"/>
  <forward path="要转发的页面比如管理员" name="GoAdminView"/>
         </action>
//////////////////////////////////////////////////////////////////////////////////////////////////// -->

   <!-- 配置用户的Action -- 对应 -->
<!-- userForm -->
         <action attribute="userForm"
input="/jsp/errors.jsp"
     name="userForm"
parameter="status"
path="/jsp/user"
scope="request"
type="org.我的项目.struts.action.UserAction">
<forward name="registersuccess" path="/jsp/index.do?status=list"></forward><!-- 配置局部跳转 -->
<forward name="registerfailure" path="/jsp/register.jsp"></forward>
<!-- 配置局部异常处理
           <exception type="" key=""/>
        -->
</action>

<!-- 此处的意思是直接交给spring容器掌管了
<action attribute="loginForm"
name="loginForm"
path="/login"
scope="request"
type="org.springframework.web.struts.DelegatingActionProxy" 此处的意思是直接交给spring容器掌管了/>
-->


</action-mappings><!-- action-mappings 结束 -->

<!-- 5 ------------------------------------------------------------------------------------ -->
<!--
   名称:controller
   描述:用于配置ActionServlet
   数量:最多一个
   属性:
@bufferSize:指定上传文件的输入缓冲的大小.默认为4096
@className:指定当前控制器的配置类.默认为org.apache.struts.config.ControllerConfig
@contentType:指定相应结果的内容类型和字符编码
@locale:指定是否把Locale对象保存到当前用户的session中,默认为false
@processorClass:指定负责处理请求的Java类的完整类名.默认org.apache.struts.action.RequestProcessor
@tempDir:指定文件上传时的临时工作目录.如果没有设置,将才用Servlet容器为web应用分配的临时工作目录.
@nochache:true时,在相应结果中加入特定的头参数:Pragma ,Cache-Control,Expires防止页面被存储在可数浏览器的缓存中,默认为false
-->

<!-- 配置RequestProcessor插件
    <controller processorClass="com.项目.MyRequestProcessor"></controller>
-->

    <!-- 自定义RequestProcessor 用于解决汉字乱码和Spring集成问题 -->
<controller processorClass="com.项目.processor.EncodingProcessor"/>

    <!--
<controller contentType="text/html;charset=UTF-8"
   locale="true"
   processorClass="CustomRequestProcessor">
</controller>
-->

<!-- 6 ------------------------------------------------------------------------------------ -->

<!--
   名称:message-resources
   描述:配置Resource Bundle.
   数量:任意多个
   属性:
@className:指定和message-resources对应的配置类.默认为org.apache.struts.config.MessageResourcesConfig
@factory:指定资源的工厂类,默认为org.apache.struts.util.PropertyMessageResourcesFactory
@key:
@null:
@parameter:
-->

<!-- 配置国际化资源文件 -->
<message-resources parameter="com.项目.resource.ApplicationResources"/>

<!--
<message-resources
   null="false"
   parameter="defaultResource"/>
<message-resources
   key="images"
   null="false"
   parameter="ImageResources"/>
-->

<!-- 7 ------------------------------------------------------------------------------------ -->

<!-- 配置Title标记库插件 -->
<plug-in className="org.apache.struts.title.TitlesPlugin">
     <set-property property="definitions-config" value="/WEB-INF/title-defs.xml"/>
    </plug-in>

<!-- 8 ------------------------------------------------------------------------------------ -->

<!-- 配置表单验证组件 -- validate验证文件
<plug-in classNme="org.apache.struts.validator.ValidatorPlugin">
     <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/>

<set-property property="stopOnFirstError" value="false">
</set-property>
-->

<!--
   名称:plug-in
   描述:用于配置Struts的插件
   数量:任意多个
   子元素:set-property
   属性:
@className:指定Struts插件类.此类必须实现org.apache.struts.action.PlugIn接口
-->
<plug-in
   className="org.apache.struts.validator.ValidatorPlugIn">
   <!--
名称:set-property
描述:配置插件的属性
数量:任意多个
属性:
@property:插件的属性名称
@value:该名称所配置的值
   -->
   <set-property
property="pathnames"
value="/WEB-INF/validator-rules.xml,/WEB-INF/vlaidation.xml"/>
</plug-in>

<set-property property="stopOnFirstError" value="false"></set-property>

<!-- 9 ------------------------------------------------------------------------------------ -->

<!-- 配置spring插件 -->
<plug-in className="org.springframework.web.struts.ContextLoaderPlugin">
     <set-property property="contextConfigLocation" value="/WEB-INF/applicationContext.xml"></set-property>
    </plug-in>

<!-- 10 ------------------------------------------------------------------------------------ -->

<!-- 配置Plugin插件 -->
   <plug-in className="com.项目.MyPlugin">

<!-- 11 ------------------------------------------------------------------------------------ -->

</struts-config> <!-- struts-config 结束 -->
 

分享到:
评论

相关推荐

    struts-config.xml struts标准配置文件 struts-config

    struts-config.xml struts标准配置文件 struts-config

    Struts框架中struts-config.xml文件配置小结

    ### Struts框架中struts-config.xml文件配置详解 #### 一、引言 在Java Web开发领域,Struts是一个非常重要的MVC(Model-View-Controller)框架,它极大地简化了Web应用程序的开发过程。而在Struts框架中,`struts...

    struts-config.xml配置文件详解

    在 Struts-config.xml 文件中,数据源配置是通过 `&lt;data-sources&gt;` 元素实现的,该元素可以包含多个 `&lt;data-source&gt;` 子元素,每个 `&lt;data-source&gt;` 元素可以配置一个数据源。数据源配置中可以设置 driverClass、url...

    Struts struts-config.xml配置

    而`struts-config.xml`配置文件则是Struts应用的核心配置文件,它负责管理Struts应用中的各种组件配置。本文将详细介绍`struts-config.xml`配置文件的关键组成部分及其作用。 #### 二、文件结构 `struts-config.xml...

    struts-config.xml

    `struts-config.xml`是Struts框架的核心配置文件,它定义了应用的各个组件及其交互方式。下面将详细介绍这个配置文件的主要元素和子元素。 ### 主要元素 1. **`&lt;data-sources&gt;`**: 这个元素用于配置数据源,通常...

    配置struts--config.xml详解

    在 Struts 应用程序中,`struts-config.xml` 文件是核心配置文件,它定义了应用的行为、控制器(Actions)、数据源(Form Beans)以及视图(JSP 页面)之间的关系。本文将深入探讨 `struts-config.xml` 的主要元素和...

    Struts-config.xml配置详解

    下面将详细介绍struts-config.xml中8个主要配置元素的功能和使用方法。 1. &lt;data-sources&gt;元素:该元素用于配置数据源,数据源是应用程序连接数据库时使用的一个中间层。在Java中,数据源通常是通过实现javax.sql....

    struts-config.xml配置详解

    韩顺平视频配套struts-config.xml配置详解.txt

    SSH之Struts1之struts-config.xml常用配置详解(3-21-2008)

    SSH之Struts1之struts-config.xml常用配置详解(3-21-2008)

    struts-config.xml配置详解.txt

    这个strut-config配置详解是韩顺平老师指定的 很多同学都看过韩老师的视频或者上过韩老师的课程吧

    struts-config.xml配置

    Struts框架支持基于XML的表单验证,这允许在`struts-config.xml`中定义验证规则,或者在ActionForm类中实现自定义的校验逻辑。 ```xml &lt;global-validators&gt; &lt;validator name="required" path="/WEB-INF/validators...

    struts-config.xml 详解

    `struts-config.xml`是Struts框架的核心配置文件,它定义了应用程序的行为和组件之间的交互。这个文件的主要目的是提供一个集中式的配置点,用于设置数据源、表单bean、异常处理、动作映射等关键元素。以下是每个...

    org.springframework.web.struts-3.1.0.M2.jar

    同时,Struts的配置文件(struts-config.xml或struts2的struts.xml)也需要进行相应的调整,引入Spring的插件和配置信息。 `springframework-license.txt`文件则包含了Spring框架的许可协议,它规定了软件的使用、...

    struts-config.xml 文件详解

    struts-config.xml 文件详解 以下是一份完整的struts-config.xml文件,配置元素的说明详见注释.

    struts--config.xml详解

    struts--config.xml详解

    在struts-config.xml中配置数据源

    在Struts框架中,`struts-config.xml`是核心配置文件,用于定义动作映射、数据源等关键组件。本篇文章将深入探讨如何在`struts-config.xml`中配置数据源,以及这在实际开发中的意义和作用。 数据源(DataSource)是...

    Struts-config.xml 配置详解.doc

    Struts-config.xml是Struts框架的核心配置文件,用于定义应用程序的行为和组件间的交互。这个XML文件按照特定的结构和约定来组织,包含了多个主要元素,这些元素定义了数据源、表单bean、全局转发、动作映射、控制器...

Global site tag (gtag.js) - Google Analytics